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(57) Abstract 

A medical imaging system for communicating image information between a plurality of different medical imaging modalities (12) 
having different input protocols and a plurality of different laser imagers (18) having different output protocols takes advantage of a 
reusable, object-oriented software architecture having a plurality of functionally independent components. The individual components can 
be configured in a communication pipeline (26) to communicate image information between a medical imaging modality (12) and a laser 
imager (18) according to desired protocols in a networked manner. Each component can be interchanged with a differently configured 
component to facilitate communication of image information according to a different protocol, thereby reconfiguring the pipeline (26) 
to achieve significant flexibility. The software architecture is scalable to produce a plurality of communication pipelines (26), each of 
which can be configured according to desired protocols. Thus, the system can support a different protocol by either swapping components 
to reconfigure a single communication pipeline (26), ot by simply selecting an alternative among a plurality of differently configured 
communication pipelines (26) in the scalable architecture. The software architecture is equipped with a network executive component (14) 
designed to configure one or more communication pipelines (26) for network communication. 
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SYSTEM FOR NETWORK COMMUNICATION OF IMAGE 
INFORMATION BETWEEN IMAGING DEVICES ACCORDING TO 
MULTIPLE PROTOCOLS 

5 

Field of the Invention 

The present invention relates to imaging systems, and, more particularly, to 
systems for communicating image information between an input imaging device and 
an output imaging device in a network environment. 

10 

Background to the Invention 

An imaging system typically includes an input imaging device that generates 
image information, and an output imaging device that forms a visible representation 
of an image based on the image information. In a medical imaging system, for 

1 5 example, the input imaging device may include a diagnostic device, such as a 

magnetic resonance (MR), computed tomography (CT), conventional radiography 
(X-ray), or ultrasound device. Alternatively, the input imaging device may include a 
user interface device, such as a keypad, mouse, or trackball, which is also capable of 
generating medical image information. As a further alternative, the input imaging 

20 device may include an image archival workstation for retrieving archived image 
information. The output imaging device in a medical imaging system typically 
includes a digital laser imager. The laser imager exposes an imaging media in 
response to the image information to form the visible representation. 

The image information generated by the input imaging device includes image 

25 data containing digital image values representative of the image, and imaging requests 
specifying operations to be performed by the laser imager. Each of the digital image 
values corresponds to one of a plurality of pixels in the original image, and represents 
an optical density associated with the respective pixel. In response to an imaging 
request, the laser imager converts the digital image values to generate laser drive 

30 values used to modulate the intensity of a scanning laser. The laser drive values are 
calculated to produce exposure levels, on the imaging media, necessary to reproduce 
the optical densities associated with the pixels in the original image when the media is 
developed, either by wet chemical processing or dry thermal processing. The laser 
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imager may perform a number of additional operations in response to the imaging 
requests generated by the input imaging device. For example, the laser imager may 
manipulate the image data, prior to generating the laser drive values, to produce a 
variety of different format and/or appearance characteristics. 
5 The image information processed by the laser imager has a format determined 

by an input protocol associated with the particular input imaging device. Medical 
imaging systems typically are capable of handling image information generated 
according to a variety of diverse input protocols An input protocol can be 
characterized as including a network driver protocol, which provides lower-level 

10 communications specifications as to a particular input imaging device, and a network 
interpreter protocol, which determines the format for interpreting image information 
generated by the input imaging device. The number of different input protocols 
results, to some degree, from the various types of input imaging devices presently in 
use, e.g., a magnetic resonance (MR), computed tomography (CT), conventional 

15 radiography (X-ray), or ultrasound device, each of which may generate image 

information according to a different protocol. The primary source of different input 
protocols is, however, the existence of a number of modalities, i.e., input imaging 
devices made by different manufacturers and having unique, manufacturer-specific 
- input protocols. For example, manufacturers such as Siemens, Toshiba, GE, and 

20 Picker presently make CT-type input imaging devices that provide similar 

functionality, but which generate image information according to different modality- 
specific input protocols. 

In addition to the ability to handle multiple input protocols, medical imaging 
systems typically are capable of handling communication of image information to 

25 output imaging devices according to multiple output protocols. Like an input 
protocol, an output protocol can be characterized as including an output driver 
protocol, which determines requirements for communication with a particular output 
imaging device, and an output interpreter protocol, which determines the format for 
translating image information into a form understood by the output imaging device. 

30 Different output protocols primarily result from the availability of laser imaging 

output devices having different sets of functional capabilities. The different sets of 
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functional capabilities present varying complexity that can lead to different output 
protocols. For example, Imation Enterprise Corp. ("Imation"), of Oakdale, 
Minnesota, presently offers laser imagers having different sets of functional 
capabilities referred to as the "83 1," M 952," and "SuperSet" sets, each of which is 
5 associated with a set-specific output protocol. 

Existing medical imaging systems presently accommodate multiple input and 
output protocols on an ad-hoc basis by the design of point-to-point hardware and/or 
software interfaces specifically configured for a particular input protocol and a 
particular output protocol. The use of a custom-made interface is extremely 
10 inflexible. If communication with a different input imaging device is later required, 
the entire interface must be redesigned to handle the relationship between the new 
input protocol and the old output protocol. A change in the output imaging device 
similarly requires redesign of the interface to handle the relationship between the new 
output protocol and the old input protocol. Unfortunately, redesign of the interface 

15 is a cumbersome task that often requires a significant investment in hardware and/or 
software development time. Even seemingly minor modifications in functionality of 
an input or output imaging device can produce numerous, costly design changes that 
propagate throughout the interface. 

One solution to these problems is described in U. S. Patent No. 5,630,101. 

20 The system described in this patent application adopts an object-oriented, modular 
design in effecting a software-based direct-connect architecture to allow for 
significant flexibility in laser imager communication. An interface executive 
instantiates the needed input driver-input interpreter pair and the needed output 
interpreter-output driver pair to create a pipeline so that a particular host modality 

25 can communicate with a particular laser imager. Each of the input driver, input 
interpreter, output interpreter and output driver components is a discrete software 
object, or "black box " In this manner, each can be modified or replaced by a new 
object without affecting the performance of the others, or the overall pipeline. For 
example, the input interpreter and driver pair may be specific to a Siemens host 

30 modality, while the output interpreter and output driver pair may be specific to an 
Imation laser imager using the 83 1 protocol. If the latter pair is replaced with a pair 
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specific to an Imatton laser imager using the SuperSet protocol, the design of the 
components is such that the input interpreter and driver pair does not also need to be 
replaced. 

Although U. S. Patent No. 5,630,101 promotes flexibility in laser imager 
5 architecture, it discloses only a direct-connect, point-to-point architecture. For every 
input-output pair, the interface executive must instantiate a separate input driver- 
input interpreter pair and output interpreter-output driver pair. That is, the interface 
executive must create a separate pipeline between each host modality and each laser 
imager. Although not a misgiving in a system having a relatively small number of 

10 host modalities, this can pose a problem in environments where a significant number 
of host modalities communicate with a plurality of different laser imagers. This is 
especially true in a networking environment, in which typically a number of network 
clients all speak the same protocol. In such a situation, it is desirable not to have 
redundant a input driver-input interpreter pair for each and every client. Besides the 

15 drainage in resources, this architecture also places excessive overhead on the 
interface executive. 

Thus, there is an increasing demand for even more flexible medical imaging 
systems capable of providing communication between a variety of input and output 
imaging devices having multiple protocols. It is desirable that such medical imaging 

20 systems not only provide flexibility with respect to current protocols, but also be 
capable of adaptation to handle future protocols in a cost-effective manner. There 
also are increasing demands for network communication of image information 
between input and output imaging devices. In the medical imaging field, for example, 
the American College of Radiology (ACR) and the National Electrical Manufacturers 

25 Association (NEMA) have formed a joint committee to develop a standard for digital 
imaging and communications in medicine, known as the DICOM protocol. The 
DICOM protocol was designed to facilitate connectivity among equipment in the 
medical industry, particularly in view of the movement of hospitals from point-to- 
point environments to network environments. Medical equipment manufacturers 

30 throughout the industry are now beginning to implement the DICOM 

communications protocol. The DICOM protocol sets one standard for network 
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communication of image information. However, other network protocols exist and 
will continue to be created. Thus, protocol translation continues to be necessary in 
network systems. The need for protocol translation in network systems creates 
problems similar to those encountered with point-to-point systems. Specifically, 
5 flexibility and ease of adaptation for multiple protocols continue to be of concern. 
Accordingly, there is a need for a system capable of providing network 
communication of image information between imaging devices according to multiple 
communication protocols. 



10 Summary of the Invention 

The present invention is directed to a medical imaging system for 
communicating image information via a network between a plurality of different input 
imaging devices and output imaging devices according to different communication 
protocols. 

15 In one embodiment of the invention, a software system for communicating 

medical image information between at least one of a plurality of different input 
imaging devices and at least one of a plurality of different laser imagers via a network 
interface comprises one or more network driver components, one or more network 
interpreter components, one or more output interpreter components, one or more 

20 output driver components, one or more network executive components, and an 
interface executive component. 

Each of the network driver components is configured to receive medical 
image information from one of the input imaging devices via a network interface. 
The medical image information is received according to one of a plurality of different 

25 network driver protocols. Each of the network driver protocols is specifically 
associated with one of the input imaging devices. 

Each of the network interpreter components is configured to generate first 
imaging requests based on the medical image information received by one of the 
network driver components. The first imaging requests are generated according to 

30 one of a plurality of different network interpreter protocols. Each of the network 
interpreter protocols is specifically associated with one of the input imaging devices. 
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Each of the output interpreter components is configured to generate second 
imaging requests based on the first imaging requests generated by one of the network 
interpreter components. The second imaging requests are generated according to 
one of a plurality of different output interpreter protocols. Each of the output 
5 interpreter protocols is specifically associated with one of the laser imagers. 

Each of the output driver components is configured to communicate the 
second imaging requests generated by one of the output interpreter components to 
one of the laser imagers. The second imaging requests are communicated according 
to one of a plurality of different output driver protocols. Each of the output driver 

10 protocols is specifically associated with one of the laser imagers. 

Each of the network executive components communicatively interconnects 
one of the network driver components and one of the network interpreter 
components. Furthermore, the interface executive component defines one or more 
network communication pipelines. Each of the pipelines communicatively 

15 interconnects one of the input imaging devices, one of the network executive 

components, one of the output interpreter components, one of the output driver 
components, and one of the laser imagers. 

The present invention provides for a number of advantages in facilitating 
communication between the input imaging devices and the laser imagers. Because 

20 the network executive components can each facilitate communication of a number of 
input imaging devices, a separate pipeline is not required for each input imaging 
device, thereby conserving resources. The network executive components also allow 
the present invention to facilitate communication between input imaging devices and 
laser imagers on a network level, as opposed to in a direct-connect manner, 

25 Furthermore, the network executive components are delegated responsibility by the 
interface executive component as to overseeing communication from the input 
imaging devices. This frees the interface executive component from itself having to 
take on this responsibility. 

In one embodiment of the present invention the software system is 

30 constructed in both an object-oriented and client-server manner, and employs remote 
procedure calls for facilitating communication among components. This gives the 
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invention the benefit of reusability of the components as new components for 
different protocols are created. Further, this gives the invention the advantage of 
seamless integration of the components, and promotes scalability of the entire 
software system. In addition, this gives the present invention the advantage of 
5 interchangeability of the components. 

Still other and further embodiments, aspects and advantages of the present 
invention will become apparent in the following description and by reference to the 
accompanying drawings. 



10 Brief Description of the Drawings 

The accompanying drawings are included to provide a further understanding 
of the present invention and are incorporated into and constitute a part of this 
specification. The drawings illustrate embodiments of the present invention and 
together with the description serve to explain the principles of the invention. 
15 FIG. 1 is a functional block diagram of a medical imaging system for 

communication of image information between multiple-protocol imaging devices in a 
network communication environment, in accordance with the present invention; 

FIG. 2 is a functional block diagram of an alternative medical imaging system 
for communication of image information between multiple-protocol imaging devices 
20 in a network communication environment, in accordance with a further embodiment 
of the present invention; 

FIG. 3 is a functional block diagram illustrating a sub-system of the medical 
imaging system of FIG. 1 ; 

FIG. 4 is a diagram illustrating the object-oriented protocol hierarchy that 
25 facilitates interchangeability of the network protocol components, including both the 
network driver component and the network interpreter component; 

Fig 5 is a diagram illustrating the object-oriented protocol hierarchy that 
facilitates interchangeability of the output interpreter component and the output 
driver component; and, 
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FIG. 6 is a functional block diagram of a client-server relationship applicable 
to the medical imaging system shown in FIG. 1, in accordance with the present 
invention. 



5 Detailed Description of the Drawings 
Overview of the present invention 

The present invention effects a scalable software architecture for 
simultaneously translating multiple medical imaging protocols within a network 
paradigm. Referring to FIG. 1, a functional block diagram of a medical imaging 

10 system 10 for communication of image information between multiple-protocol 

imaging devices in a network communication environment, in accordance with the 
present invention, is shown. The system 10 includes a plurality of input imaging 
devices in the form of network clients 12, one or more network executive 
components 14, one or more output interface components 16, an output imaging 

15 device 18, and an interface executive component 20. Each output interface 

component 16 includes an output interpreter component 22 and an output driver 
component 24. 

As shown in FIG. 1, each of clients 12 communicates with output imaging 
device 18 via a particular pipeline 26 specific to a particular protocol. Thus, so long 

20 as each of clients 12 speaks the same one protocol, only one pipeline 26 is needed to 
provide for communication between the clients 12 and output imaging device 18. 
Further, if each of clients 12 speaks one or two of two different protocols, then two 
different pipelines are needed; and so on. In this manner, the present invention allows 
for N different pipelines for N different protocols, in which each pipeline is capable of 

25 handling M different clients speaking that particular protocol. That is, a separate 
pipeline for each client is not required, but rather only for each different protocol. 

Each pipeline 26 comprises three primary components: a network executive 
component 14, an output interpreter component 22 and an output driver component 
24, the latter two of which are paired as a single output interface component 16. 

30 Broadly speaking, the system shown in FIG. 1 is set up in the following manner. For 
every output imaging device 18, the interface executive component 14 creates a 
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separate pipeline 26 for each separate protocol spoken by at least one network client 
12 that may communicate with imaging device 18. The interface executive 
component 14 accomplishes this by instantiating a network executive component 14 
specific to the protocol spoken by one or more clients 12, and an output interface 
5 component 16 specific to output imaging device 18, a pair of particular components 
14 and 16 thus making up a particular pipeline 26. This creation of pipelines 26 can 
occur either "on the fly" as clients speaking different protocols enter or leave the 
network of system 10, or can occur when the network is first being initialized. The 
present invention is not limited either way. 
10 Upon establishment of the pipelines 26, a client 12 speaks to the output 

imaging device 18 in general terms in the following manner. Network executive 
component 14 filters and interprets requests received from client 12 to corresponding 
first requests that output interface component 16 understands. Upon transmission to 
interface component 16, the first requests are further filtered and interpreted, to the 

15 particular corresponding second requests that output imaging device 18 understands. 
In this manner, the present invention takes requests specific to a particular protocol, 
translates them into first requests, and further translates them into second requests 
specific to a particular imaging device. Thus, component 14 and component 16 can 
be changed independent of one another, because both speak to one another via first 

20 requests. Put another way, the implementation of a network executive component 14 
specific to a particular protocol is independent of any imaging device 1 8, while the 
implementation of output interface component 16 is independent of any given 
protocol spoken by a particular client 12. Note as well that this process as described 
is operable in reverse, such that requests from device 18 can be sent to client 12. 

25 The present invention thus adopts a pipeline model for allowing 

communication between M clients speaking N protocols to an imaging device. The 
interface executive component manages creation of these pipelines. A pipeline is 
created for each particular protocol spoken by at least one of M clients on the 
network. Because typically N « M, the present invention conserves resources over 

30 a system in which a separate pipeline is necessary for each client, not each protocol. 
This is a significant advantage of the present invention. 
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Referring now to FIG. 2, a functional block diagram of a further embodiment 
of the present invention is shown. Like-numbered elements of FIG. 2 as compared to 
FIG. 1 indicate that the elements are identical, and that description of them in 
conjunction with FIG. 1 applies equally in conjunction with FIG. 2. As an alternative 
5 to instantiating N full translation pipelines, the interface executive component may be 
configured to instantiate one translation pipeline with N network executive 
components operating independently and in parallel to one another. In this manner, 
NxM clients may be supported without the inefficiency of providing N-l output 
interpreter components and N-l output driver components. The system 58 of FIG. 2 

10 supports N network protocols and N x M network clients with the implementation of 
only one communication pipeline. System 58 includes a plurality of network 
executive components 14 that listen for network clients 12 having particular network 
protocols. The interface executive component 20 communicatively interconnects 
each of network executive components 14 with a single output interpreter 

15 component 22, a single output driver component 24, and a single output imaging 

device 18 to provide a single communication pipeline with multiple, protocol-specific 
network inputs. 

Thus, the embodiment of the present invention as shown in FIG 2 varies from 
that shown in FIG. 1 in that the former embodiment conserves even more resources 

20 than does the latter. In the case where there is one output imaging device but 

multiple network protocols, the embodiment shown in FIG. 1 wastes some resources 
by providing redundant output interface components 16 for each pipeline 26, which 
are all redundant due to the fact that there is only one output imaging device. This 
redundancy, and corresponding waste of resources, is eliminated by the embodiment 

25 shown in FIG. 2. In FIG. 2, there is only one pipeline 26, and only one output 
interface component 16, to which each of network executive components 14 is 
coupled. Other than this redundancy reduction, FIG. 2 operates identically to FIG. 1, 
and description made in conjunction with FIG 1 should be referred to for description 
of FIG. 2; 
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Implementation of the Present Invention 

Referring again to FIG. 1, the network executive components 14, output 
interface components 16, and interface executive component 20 are implemented in 
one embodiment as an object-oriented software system that interfaces with a network 
5 having network clients 12 and output imaging device 18. The software system may 
be implemented as part of an output imaging device 1 8, such as a continuous tone 
digital laser imager, or as part of a discrete interface device controlling 
communication of image information between network clients 12 and output imaging 
device 18. 

10 In one embodiment of the invention, the network comprises a plurality of 

different clients, such as magnetic resonance (MR), computed tomography (CT), 
conventional radiography (X-ray), and ultrasound devices, manufactured by a number 
of different manufacturers, such as Siemens, Toshiba, GE, or Picker. The laser 
imager can be any of a number of different imagers, such as those manufactured by 
15 Imation and that understand the 83 1, 952, or SuperSet protocols The laser imager 
may also reside directly on the network, in which case the software system typically 
resides on a hardware card inserted into the laser imager. The card typically 
comprises input/output (IO) circuitry, as well as memory such as a ROM or flash 
ROM, which is one type of reprogrammable ROM. The software system resides on 

20 this memory. 

In the alternative, the laser imager does not reside directly on the network, 
and instead is coupled to the network via an intermediary computer that itself resides 
directly on the network. The intermediary computer typically has a random-access 
memory (RAM), a read-only memory (ROM), a central-processing unit (CPU) and a 

25 storage device, such as a hard disk drive, programmable ROM, or disk drive. In this 
case, the software system typically resides on the storage device of the intermediary 
computer, and is copied into RAM and executed therefrom by the CPU. Where the 
storage device is a disk drive or other removable storage device, the software system 
can be stored on the storage medium for insertion into the device. The present 

30 invention is not, however, limited to any particular hardware implementation. 
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The image information generated by the input imaging devices associated 
with network clients 12 includes both requests for imaging operations, and image 
data containing digital image values representative of an image to be handled by 
output imaging device 18. For purposes of this description, pipeline 26 will be 
5 described as handling communication of image information in the form of imaging 
requests, with image information in the form of digital image values representative of 
the image being communicated by a separate communication path. It is within the 
scope of the invention, however, that pipeline 26 could be configured to handle 
communication of image information in the form of both requests for imaging 

10 operations and image data containing the digital image values. 

In a typical medical imaging system, imaging requests include requests to 
initiate an image print job by output imaging device 18, requests to abort a previously 
initiated image print job, requests to define or modify a format of an image to be 
printed, requests to delete a set of image data representative of a previously acquired 

IS image, and requests to store image data in a particular image location. 
Components of the Invention: Interface Executive Component 

The interface executive component 20 defines one or more (1 to N) 
communication pipelines 26. Each communication pipeline 26 communicatively 
interconnects, or "binds," one or more of the M network clients 12, one of network 

20 executive components 14, one of output interpreter components 22, one of output 
driver components 24, and output imaging device 18 in a bi-directional manner. The 
output imaging device 18 may communicate with any of pipelines 26 on a shared 
basis. Alternatively, a plurality of output imaging devices 18 could be provided, each 
being communicatively interconnected with a particular pipeline 26. 

25 The interface executive component 20 provides for the highest level of 

intelligence within system 10 of FIG. 1. It governs and manages the particular 
network components 26 and output interface components 16 needed for clients 12 to 
communicate with device 18. That is, as shown in FIG. 1, based on the N different 
protocols spoken by clients 12, the interface executive component 20 instantiates a 

30 particular pipeline 26 made up of a network executive component 26 and output 

interface component 16. Furthermore, if there are P different output imaging devices 

12 
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(as opposed to just one, as shown in FIG. 1), then the interface executive component 
instantiates N x P different pipelines, one for every unique imaging device-protocol 
pair. This can be accomplished in a separate set-up mode, or u on the fly" as clients 
speaking different protocols enter or leave the network. 

Although having the most intelligence of any component within the present 
invention, the interface executive component 20 differs from the interface executive 
component disclosed and described in United States patent application serial no. 
08/343, 1 84 in that it has less intelligence than the interface executive component 
disclosed in that patent application. The interface executive component disclosed and 
described in United States patent application serial no. 08/343,184 instantiates an 
input interface component particular to every client needing to communicate with a 
particular imaging device. That is, the interface executive component constructs a 
pipeline on a client-by-client basis. Conversely, the interface executive component of 
the present invention instantiates a network executive component 14 specific to a 
particular protocol, and thereto delegates all responsibility of serving network clients. 
Thus, the interface executive component of the present invention constructs a 
pipeline on a protocol-by-protocol basis. It therefore has less intelligence in that it 
does not micromanage communications with particular clients as does the interface 
- executive component of United States patent application serial no. 08/343,184. That 
is, the latter interface executive component "knows" ail details regarding the input 
device, whereas the interface executive component of the present invention simply 
"knows" that there are input devices residing on a network, and delegates 
responsibility for handling implementation of the interface as to the input devices to 
the network executive component 14. 

The interface executive component 20 defines the structure of pipeline 26. 
The pipeline 26 is configured to communicatively interconnect a number of 
components 30, 32 (which are shown in FIG. 3 and, as shown there and as will be 
explained later, are instantiated by network executive component 14), 22 and 24 
having different protocols on a selected basis to provide significant flexibility. This 
flexibility provides a medical imaging system 10 capable of achieving communication 
between a variety of different network clients 12 and one or more output imaging 
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devices 18 having a variety of different functional capabilities. Thus, interface 
executive component 20 treats each functionally independent component 14, 22 and 
24 as a "black box" with a clearly identified set of responsibilities and a defined 
interface. The interface executive component 20 selects the appropriate series of 
5 black boxes based on the environment, and binds them together with "handles" to 
one another to form the complete pipeline 26. As a further advantage, interface 
executive component 20 in one embodiment is configured to dynamically bind the 
components "on the fly" to form a communication pipeline 26 appropriate for the 
current imaging environment. Moreover, interface executive component 20 is 

10 configured to produce a scalable software architecture having a plurality of 
communication pipelines 26 configured according to different protocols. The 
scalable architecture enables output imaging device 1 8 to communicate 
simultaneously with several network clients 12 on a shared basis using the necessary 
protocols, as provided by each pipeline 26. Alternatively, a plurality of output 

15 imaging devices 18 can be provided, each being communicatively interconnected with 
a particular pipeline 26. 

Thus, the interface executive component 20 scales the software architecture 
to match the requirements of the environment, creating as many network executive 
components and pipelines as there are different network protocols. The interface 

20 executive component 20 selectively binds a series of components 14, 22 and 24 
having specific protocols necessary to match a particular network client 12, a 
particular output imaging device 18, and the required hardware interfaces. 
Components of the Invention: The Network Executive Components 

The network executive component 14 is responsible for handling all network 

25 clients 12 that communicate via a particular protocol. As shown in FIG. 1, a network 
executive component 14 is provided for each particular one of N network protocols. 
Thus, network executive component 14 handles multiple network clients 12 
simultaneously. The interface executive component 20 delegates to network 
executive component 14 the responsibility of managing all network-specific services. 

30 The interface executive component 20 instantiates a particular network executive 
component 14 for each medical imaging network protocol that will be supported on 
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the network by system 10. If the Picker Networking Protocol is to be supported, for 
example, interface executive component 20 instantiates a network executive 
component 14 capable of serving such a protocol. For further example, the interface 
executive component 20 also instantiates another network executive component 
5 capable of serving the DICOM protocol, if that protocol is to be supported. 

The network executive component 14 governs all objects needed to manage 
network communication. The primary function of network executive component 14 
is to monitor or "listen" at network interface 28 for imaging requests from network 
clients 12 having a particular network protocol. When a network client 12 requests 

10 access to output imaging device 18 via a particular network protocol, network 
executive component 14 spawns a network driver component 30 and a network 
interpreter component 32 appropriate for that protocol, as shown in FIG. 3. Further, 
network executive component 14 binds network driver component 30 to network 
interpreter component 32, and then binds network interpreter component 32 to 

15 output interpreter component 22 using handle information previously provided by the 
interface executive component 20. The network executive component 14 then 
returns to listening to network interface 28 for new requests sent according to the 
particular network protocol. The network driver component 30 and network 
interpreter component 32 together form a network interface component 33, as is also 

20 shown in FIG. 3. 

The presence of the network executive component in the present invention 
serves as a distinguishing characteristic of the invention over U.S. Patent No. 
5,630,101. In U.S. Patent No. 5,630,101, there is no corresponding network 
executive components, but rather there are input interface components. The input 

25 interface component, however, is not an intelligent component as is the network 

executive component of the present invention. Rather, an input interface component 
is instantiated by the interface executive for every connection between a particular 
client and the imaging device. Conversely, in the present invention the interface 
executive delegates responsibility for client communication to a network executive 

30 component, which itself instantiates other components as necessary for one or more 
clients speaking a common protocol to communicate with the imaging device. 

15 
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The network executive components thus provide the present invention with 
the advantage of network communication in a resource use-minimizing manner. For 
example, overlaying the system disclosed in U.S. Pat. No. 5,630,101 onto a network 
of clients results in the creation of pipelines for each of the clients. However, by 
5 incorporating client communication in an intelligent network executive component 
14, the present invention eliminates the need for the creation of pipelines for each of 
the clients, but rather only calls for the creation of a pipeline for each of the protocols 
via which the clients can communicate. Because the number of communication 
protocols is typically far less than the number of clients, this results in a significant 

10 savings in resource use. Furthermore, by delegating the responsibility for client 
communication to the network executive component 14, the interface executive 
component 20 is freed from such micromanagement duties, which may otherwise 
overburden the interface executive component. 

In one embodiment, network driver and network interpreter components 30 

1 5 and 32 as shown in FIG. 3 are instantiated M on the fly" in response to detection by 

network executive component 14 of a network client 12 having a specific protocol at 
network interface 84, thereby conserving the hardware/software resources necessary 
to support such components until needed. This dynamic instantiation of the network 
driver and network interpreter components 30, 32 enables reduction in the amount of 

20 system overhead that otherwise would be necessary. If resource conservation is not a 
concern, such components are alternatively provided on a permanent basis to provide 
a fixed, dedicated pipeline 26 for each protocol. 

Once the network driver component 30 and network interpreter component 
32 have been created, network executive component 14 delegates all responsibility 

25 for serving the particular network client 12 to the driver/interpreter pair. The 

network executive component 14 communicatively binds network client 12, network 
driver component 30, and network interpreter component 32 to one of output 
interpreter components 22, using handle information previously provided to the 
network executive component 14 by the interface executive component 20. 

30 Each of network driver components 30 is configured to receive the image 

information from a network client 12 according to one of a plurality of different 
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network interface protocols. Each network interface protocol is specifically 
associated with one of network clients 12, and reflects the modality-specific 
requirements for communication with the particular network client. Each of the 
network interpreter components 30 is configured to generate first imaging requests 
5 according to one of the network interface protocols based on the content of the 
received image information. The first imaging requests are generated by network 
interpreter component 32, and correspond to imaging requests generated by network 
client 12. The first imaging requests are communicated to output interface 
component 16. 

10 Each of the network interface protocols includes both a network driver 

protocol applicable to network driver components 30 and a network interpreter 
protocol applicable to network interpreter components 32. The appropriate network 
driver protocol is determined by the communication requirements of a particular 
network client 12, whereas the appropriate network interpreter protocol is 

15 determined by the image information format of the particular input imaging device 

associated with the network client. The image information format refers to the types 
of imaging requests generated according to the protocol of a particular input imaging 
device. The network driver protocol specifies the manner in which a network driver 
component 30 should cany out the transfer of image information from an input 

20 imaging device associated with a network client 12. The network interpreter 

protocol specifies the manner in which network interpreter component 32 should 
interpret the image information to generate the first imaging requests. The network 
driver and network interpreter protocols can vary significantly according to 
differences in the type of network client 12, as well as the manufacturer of the input 

25 imaging device 18. 

The network interpreter component 32 also shares a common set of tasks 
with other network interpreter components, without regard to a specific network 
interpreter protocol. Primarily, after obtaining image information from a network 
driver component 30, a network interpreter component 32 analyzes requests 

30 contained in the image information and translates them to generate first imaging 
requests corresponding to operations provided by output imaging device 1 8. The 
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first imaging requests include requests for a variety of common imaging services 
provided by output imaging device 1 8. 

The manner in which network interpreter component 32 interprets the 
requests generated by network client 12 may vary according to the specific network 
5 interpreter protocol. The network interpreter component 32 understands the precise 
format, instructions, and timing constraints inherent in the image information 
generated by a particular network client 12. Nevertheless, all network interpreter 
components 22 still provide a common, basic function of generating first imaging 
requests. The network interpreter component 32 sends the first imaging requests 

10 along pipeline 26. Once the first imaging requests have been processed by 

downstream components in bi-directional pipeline 26, and a response has been 
received, network interpreter component 32 forms an appropriate response for 
network client 12. The network interpreter component 32 sends the response along 
pipeline 26 to network client 12, via network driver component 30, which handles 

15 communication requirements necessary to transmit the response to the input imaging 
device. 

The network driver component 30 and network interpreter component 32 
have been described in recognition that a network interface component 33 could 
alternatively be implemented as a single, integral software module. In the 

20 embodiment described, however, a network interface component 33 is realized by a 
discrete network driver component 30 and a discrete network interpreter component 
32. A discrete implementation of the sub-components divides the functionality of 
each network interface component 33 into smaller packages for better modularity. 
Thus, as an example, with added modularity, changes in hardware specifications for 

25 network interface 28 require only reconfiguration of network driver component 30, 
instead of the entire network interface component 33. 

Furthermore, notwithstanding functions specific to a particular protocol, 
components 30 and 32 of like type (i.e., all network driver components) are 
configured to perform several common tasks. For example, network driver 

30 components 30 share a set of common tasks necessary to communicate with a 

network client 12 operating according to particular network protocol. A network 
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driver component 30 is configured to handle any hardware specifics such as 
interrupts, buffers and handshaking necessary to transfer imaging information to and 
from a particular network client 12. The network driver component 30 is further 
configured to handle any other specific needs of a network client 12, such as 
5 packetizing or initialization. The network driver component 30 performs all 

necessary communications tasks, isolating the remainder of pipeline 26 from any 
knowledge of the specific requirements for communication with the network client 
1 2. Thus, the responsibility of network driver component 30 is two-fold. First, 
network driver component 30 receives image information off the network from 
10 network client 12, and prepares the image information for the next stage of pipeline 
26, i.e., network interpreter component 32. Second, network driver component 30 
transmits any responses emerging from bi-directional pipeline 26 onto the network 
for communication to network client 12. 

Components of the Invention: Output Interface Components 
15 Still referring to FIG. 1, each of output interface components 16 is configured 

to generate second imaging requests according to one of a plurality of different 
output protocols, via one of output interpreter components 22, based on the content 
of the first imaging request. The second imaging requests represent the content of 
the first imaging requests, as translated by output interpreter component 22 for 
20 communication to output imaging device 1 8. Each output interface protocol is 
specifically associated with the type of output imaging device 18 and, like the 
network interface protocol, reflects the requirements for communication with the 
particular output imaging device. In addition, each of the output interface 
components 16 is configured to communicate the second imaging requests to output 
25 imaging device 1 8, via output driver component 24, according to one of the output 
interface protocols. 

Each of the output interface protocols includes an output interpreter protocol 
applicable to output interpreter components 22 and an output driver protocol 
applicable to output driver components 24. The output driver protocol is determined 
30 by the communication requirements of output imaging device 1 8, whereas the 
appropriate output interpreter protocol is determined by the image information 
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format of the output imaging device. The output interpreter protocol specifies the 
manner in which output interpreter component 22 should interpret first imaging 
requests to generate second imaging requests in a form understood by output imaging 
device 1 8. The output driver protocol specifies the manner in which an output driver 
5 component 24 should cany out the transfer of second imaging requests to output 
imaging device 18. Like the network interface protocols, the output interface 
protocols are subject to variation. For example, both the output driver and output 
interpreter protocol can vary according to the type of functional capabilities provided 
by output imaging device 18, e.g., 831, 952, or SuperSet in the case of a laser imager 

1 0 manufactured by Imatioa 

An output interpreter component 22 is configured to receive, via pipeline 26, 
first imaging requests generated by a network interpreter component 32, and to 
interpret the first imaging requests to generate second imaging requests, which 
conform to the particular protocol required by output imaging device 18. The second 

1 5 imaging requests correspond to the first imaging requests in substance, but are 

configured according to the output protocol understood by output imaging device 
18. Thus, the second imaging requests serve as requests for the same imaging 
services specified by first imaging requests. The manner in which an output 
- interpreter component 22 interprets the instructions may vary according to the 

20 specific output interpreter protocol dictated by output imaging device 1 8, but all 

output interpreter components 22 share a common task of generating second imaging 
requests in a protocol understood by the output imaging device. The output 
interpreter component 22 sends the second imaging requests along pipeline 26. 
When output imaging device 18 processes the second imaging requests and 

25 formulates a response received via pipeline 26, output interpreter component 22 

removes any output protocol-specific information and forms an appropriate response 
for network interpreter component 32. 

Referring now to the output driver component 24, like network driver 
components 30, all output driver components 24 perform a common set of 

30 communication tasks. Specifically, an output driver component 24 is configured to 
handle any hardware specifics such as interrupts, buffers, and handshaking necessary 
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to transfer imaging information to and from a particular output imaging device 18. 
The output driver component 24 isolates the remainder of pipeline 26 from any 
knowledge that communication with output imaging device 18 is carried out via a 
serial interface, a parallel interface, or a dual-port RAM, etc. The output driver 
5 component 24 transmits second imaging requests generated by an output interpreter 
component 22 to output imaging device 18, maintaining any communication 
requirements. Further, output driver component 24 receives responses from output 
imaging device 18, and prepares the response for transmission to output interpreter 
component 22 via bi-directional pipeline 26. 
10 The output interpreter component 22 and the output driver component 24 

have been described in recognition that an output interface component 16 could 
alternatively be implemented as a single, integral software module. In the 
embodiment described, however, an output interface component 16 is realized by a 
discrete output interpreter component 22 and a discrete output driver component 24. 
15 A discrete implementation of the sub-components divides the functionality of each 
interface component 16 into smaller packages for better modularity. Thus, as an 
example, with added modularity, changes in hardware specifications for interface 
component 16 require only reconfiguration of output driver component 24, instead of 
the entire interface component 16. 
20 Object-Oriented Nature of the Components 

To facilitate the interchangeability of the components, as has been described, 
the software interfaces between components 30, 32, 22 and 24 must be pre-defined 
to make each type of component generic. At the same time, however, an individual 
component 30, 32, 22 and 24 must be configured to implement functions specific to a 
25 particular protocol. Object-oriented techniques, particularly that of inheritance, are 
used by the present invention to develop a generic base-class protocol for each type 
of component (e.g., network driver component 30). 

Inheritance is a particular object-oriented technique that serves as a 
mechanism for creating new classes from an existing class. A new class looks similar 
30 to an existing class except that it differs from the existing class in a small way; 

inheritance is employed to define the new class in terms of the existing class. The 
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existing class that serves as a source for inheritance is referred to as a base class, and 
the new class derived from the base class is referred to as the derived class. An 
existing class can serve as a base class to more than one derived class. The base class 
is a definition of a more generic class of software objects, while the classes derived 
5 from the base class define more specific or specialized cases of the objects. Thus, the 
generic base-class protocol specifies the functions provided by a component and the 
procedures for accessing such functions. Each specific protocol component 
"inherits" from the corresponding base class protocol, and implements the interface to 
conform to the environment. 

10 Class inheritance allows the members of one class to be used as if they were 

members of a second class. No additional programming is required to implement the 
subclass, except for those operations that either extend or replace the members 
inherited from the other classes. As that object-oriented system is developed, 
subclasses are constructed out of existing classes until the appropriate functionality is 

15 developed. The construction of subclasses results in the formation of a class 

hierarchy. The class hierarchy is rooted in the base class, which contains a minimal set 
of behavior common to all subclasses. 

In accordance with the present invention, each component 30, 32, 22 and 24 
is configured according to a specific protocol, but also serves as a sub-class of the 

20 base class protocol. Because each component 30, 32, 22 and 24 inherits from the 
base-class protocol and implements a minimal set of functions such that they meet 
base-class requirements, it can be directly interchanged with any other component of 
like type that inherits from the same base-class protocol. The interchangeability 
resulting from the object-oriented techniques produces a "direct-connect" software 

25 architecture in which each component can be effectively plugged into pipeline 26' 
without the need for additional interface development. 

FIGS. 5 and 6 provide an example of ah object-oriented protocol hierarchy 
that facilitates interchangeability of components 30, 32, 22 and 24. The protocol 
hierarchy illustrates the implementation of components 30, 32, 22 and 24 for specific 

30 protocols that as a derived class each "inherit" from a generic base-class protocol. As 
shown in FIG. 4, a network executive base-class protocol 34 may encompass a 
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plurality of "inheriting" network executive protocols 40, 42, 44 for different network 
clients 12 such as, for example, DICOM, Picker, and LP that allow an appropriately- 
instantiated network executive component 14 to detect the presence of a particular 
network client. Similarly, a network driver base protocol 36 may encompass a 
5 plurality of "inheriting" network driver protocols 46, 48, 50 for different network 
interface requirements associated with a network client 12 such as, for example, 
DICOM, Picker, or LP. A base-class network interpreter protocol 38 may 
encompass a plurality of inheriting network interpreter protocols 52, 54, 56 for 
different types of input imaging devices or manufacturers associated with network 
10 clients 12 such as, for example, DICOM, Picker, and LP. 

As shown in FIG. 5, a base-class output interpreter protocol 35 may 
encompass a plurality of inheriting output interpreter protocols for different types of 
output imaging devices 18, such as an Imation SuperSet output interpreter protocol 
41, an Imation 831 output interpreter protocol 43, or an Imation 952 output 
15 interpreter protocol 45. Finally, a base-class output driver protocol 37 may 

encompass a plurality of inheriting output driver protocols for different hardware 
interface requirements associated with output imaging device 18, such as a dual-port 
RAM output driver protocol 47, a serial output driver protocol 49, or a parallel 
output driver protocol 51. Each of the inheriting protocols described above includes 

20 protocol-specific functions provided by a component 30, 32, 22 and 24, but 

implements such functions via a generic interface that inherits from the corresponding 
base-class protocol 34, 35, 36, 37, 38. For each base-class protocol 34, 35, 36, 37, 
38, described above, a variety of additional inheriting protocols can be implemented, 
according to the requirements of the medical imaging system environment. 

25 Therefore, the nature of components 30, 32, 22 and 24 enables them to be 

selectively "swapped" in or out of a pipeline 26 in a modular fashion by interface 
executive component 20. Each of the components 39, 32, 22, 24 is made 
interchangeable with another component of like type, but different protocol, by a 
series of software interfaces. This base-class interface is in one embodiment built into 

30 each component such that any component 30, 32, 22 and 24 in a pipeline 26 can be 
replaced without affecting the configuration of the other components in the pipeline. 
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Thus, individual components 30, 32, 22 and 24 also can be reused, significantly 
reducing costs previously associated with redesign efforts. 

For example, if pipeline 26 were to be configured for communication between 
Siemens network clients 12 and an output imaging device 1 8 implementing Imation 
5 SuperSet functionality, interface executive component 20 would first instantiate a 
network executive component 14 configured to monitor the presence of Siemens 
network clients. Upon detection of a Siemens network client 12, network executive 
component 14 would spawn a network driver component 30 and network interpreter 
component 32 configured to operate according to the Siemens network protocol. 

10 Specifically, network driver component 30 would be configured to operate according 
to a network driver protocol appropriate for receiving imaging information from the 
Siemens network client 12. The network interpreter component 32 would operate 
according to a network interpreter protocol appropriate for generation of first 
imaging requests based on the format of the image information received from the 

1 5 Siemens network client. The network executive component 1 4 then would 

communicatively bind the network driver component 30 and network interpreter 
component 32 with an output interpreter component 22 having an output interpreter 
protocol appropriate for generation of second imaging requests understood by the 
Imation SuperSet output imaging device, the network interpreter component 32 

20 already being bound to an output driver component 24 having an output driver 

protocol appropriate for communication of the second imaging requests via a serial 
hardware interface associated with the Imation SuperSet output imaging device. 

Alternatively, if a pipeline 26 were to be configured for communication 
between a Toshiba network client 12 and an Imation SuperSet output imaging device 

25 18, it would only be necessary to "swap" the network driver component 30 and 
network interpreter component 32 with components configured according to 
network driver and network interpreter protocols, respectively, appropriate for the 
Toshiba modality. Specifically, a network executive component 14 instantiated to 
listen for Toshiba network clients 12 would spawn a network driver component 30 

30 and network interpreter component 32 configured to operate according to the 

Toshiba protocol. The output interface component 16 used for Siemens network 
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clients 12 could be replicated and used in a separate communication pipeline 26 for 
Toshiba network clients. The output interface component 16 would include an 
Imation SuperSet-configured output interpreter component 22 and an Imation 
SuperSet serial-configured output driver component 24, and therefore would already 
be configured according to the requirements of output imaging device 18, 
independently of the protocol of network client 1 2. Thus, network executive 
component 14 would communicatively bind in a separate pipeline 26 the network 
driver and network interpreter components 30 and 32 with the standard output 
interpreter and output driver components 22 and 24 configured for the Imation 
SuperSet output imaging device, and useful in any pipeline having a SuperSet output 
device, and which are already bound to one another. 

As another alternative, if the pipeline 26 described above were to be modified 
for communication between a Toshiba network client 12 and an Imation 952 output 
imaging device 18, only modification of output interface component 16 would be 
necessary. Specifically, network executive component 14 would communicatively 
bind the network driver component 30 and network interpreter component 32 with 
an output interpreter component 22 having an output interpreter protocol appropriate 
for generation of second imaging requests understood by the Imation 952 output 
- imaging device, which is already bound to output driver component 24 having an 
output driver protocol appropriate for communication of the second imaging requests 
via a serial hardware interface associated with the Imation 952 output imaging 
device. Thus, the network driver and interpreter components 30, 32 spawned by 
network executive component 14 would be unaffected by a change in the output 
imaging device 28 associated with communication pipeline 26. 

Finally, if the pipeline 26 described above were to be modified for 
communication between a Toshiba network client 12 and an Imation 952 output 
imaging device 18, having a dual-port RAM interface, only modification of output 
interface component 16 would be necessary. Specifically, network executive 
component 14 would communicatively bind the network driver component 30 and 
network interpreter component 32 to an output interpreter component 22 having an 
output interpreter protocol appropriate for generation of second imaging requests 
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understood by the Imation 952 output imaging device, which is already bound to an 
output driver component 24 having an output driver protocol appropriate for 
communication of the second imaging requests via a dual-port RAM hardware 
interface associated with the Imation 952 output imaging device. Thus, network 
5 interface component 14, including Toshiba-configured network driver and interpreter 
components 30, 32 would be unaffected by the modification. 

The present invention's employment of inheritance conceptions of object- 
oriented programming provide for the advantage of reusability of network driver and 
interpreter components, as well as simplification in the creation of new network 

1 0 driver and interpreter components. Inheritance makes it possible to define new 

components by comparison with already developed components, which is known as 
differential programming. Common functionality within these components is reused, 
and therefore does not need to be redeveloped. Furthermore, any bug fixes and 
enhancements made to the base class are automatically propagated to the derived 

1 5 classes. In these ways, the present invention allows for the incorporation of new 

protocols into the software system in typically a shorter period of time, and utilizing a 
smaller number of resources, than is accomplished by the prior art. 
Client-Server Hierarchy of the Components 

As shown in FIG. 6, interface executive component 20 in one embodiment 

20 defines pipeline 26 according to a client-server architecture. In FIG. 6, an arrow 
pointing from a component A to a component B indicates that component A is a 
client component of server component B. The bi-directional arrows between 
network driver component 30 and network client 12 and between output driver 
component 24 and output imaging device 1 8 do not represent a client-server 

25 relationship, but rather the hardware/software interfaces of medical imaging system 
10. As indicated by the arrows in FIG. 6, interface executive component 20 in one 
embodiment defines the client-server relationship of the software system such that: 
(1) interface executive component 20 is a client component of network executive 
component 14, output interpreter component 22 and output driver component 24; (2) 

30 network executive component 14 is a client component of network driver component 
30 and network interpreter component 32; (3) network driver component 30 is a 
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client component of network interpreter component 32; (4) network interpreter 
component 32 is a client component of output interpreter component 22; and (5) 
output interpreter component 22 is a client component of output driver component 
24. 

5 The client-server paradigm provides for seamless integration among the 

components of the present invention. The client component requests a service to be 
performed; the server is the resource that handles the client's request. More 
specifically, the client sends a message to a server to request that the server perform a 
task, such that the server responds to the client's request. Employing client-server 

10 relationships in the present invention allows for the advantage of increased 

maintainability above and beyond that provided by object-oriented programming 
precepts. Client-server computing recognizes that the separate components provided 
for by an object-oriented architecture need not all be executed from the same memory 
space. Thus, client-server computing promotes scalability: any of the components of 

1 5 the present invention may be replaced when the need to either grow or reduce 
processing for that component dictates, without significantly impacting the other 
components. As has been described, the components of the present invention reside 
within the same memory, be it on a card within the imaging device, or within the 
RAM of a computer to which the device is coupled. However, should the number of 

20 imaging devices with which the clients can communicate become relatively large, for 
example, the output interface components for each device could reside on a card 
within the device, while the remainder of the components could reside on a computer 
attached to the network. As a result of subscription to a client-server model, the 
present invention allows for relocation of individual components without great logical 

25 effect to the other components. 

In the described client-server relationship of the present invention, output 
driver component 24 is purely a server component for output interpreter component 
22, respectively. The output driver component 24 is responsible for low-level 
hardware requirements and is under control of the higher-level output interpreter 

30 component 22, respectively. The network interpreter component 32 is a client 

component of output interpreter component 22, which provides a set of functions by 
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which the network interpreter component controls output imaging device 18. The 
output interpreter component 22 never initiates communication with network 
interpreter component 32, but rather provides services at the request of the network 
interpreter component. The network driver component 30 is a client component of 
5 network interpreter component 32, which communicates with the driver component 
30 to receive and interpret the image information from a client to generate the first 
imaging requests. The network driver component 30 itself directly communicates 
with the clients, however, according to a particular protocol. Finally, every 
component 30, 32, 22 and 24 is a server component for interface executive 
10 component 20. Thus, interface executive component 20 ultimately controls the entire 
software system. 

Communication Among the Components 

Communication among the components of the present invention is carried out 
via the issuance of remote procedure calls (RPC 's). A remote procedure call is a 

1 5 common communication mechanism often used in complex distributed software 
systems. A client component executes a particular function by issuing a remote 
procedure call to a corresponding server component. The remote procedure call 
handles all of the mechanisms necessary for inter-component communication. Each 
component is configured to provide services to a client component, but is unaware of 

20 which or how many components are actually using it as a server component. The 
server components simply perform the requests of the client components without 
exhibiting protocol-specific dependencies. 

Employment of remote procedure calls allows the present invention to have 
advantages resultant of a concept called encapsulation. Encapsulation of a 

25 component means that other components only see the services or tasks that the 
component offers, with no visibility as to how these services and tasks are 
implemented. Thus, how a component implements its actions, and how its internal 
data is arranged, is "encapsulated" inside a procedural shell that mediates all access to 
the object via remote procedure calls. Only the component itself has visibility into its 

30 procedures and its data. The components of the present invention are, therefore, 
encapsulated units of functionality. Put another way, encapsulation enables 
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information hiding and data abstraction. The actual method followed by a particular 
component is an implementation detail that is independent of how the data is used. 
Rather, the operations that can be performed on the encapsulated data are specified 
as part of the interface to the component, the remote procedure calls. Thus, the 
implementation details of the operations that manipulate the stored data can be 
changed without affecting the remote procedure calls. Along with the inheritance, the 
concept of encapsulation allows for the advantage of interchangeability of 
components within the present invention. 

In one embodiment of the present invention, a remote procedure call is used 
to execute a function in the following manner. First, when a software process being 
performed by a client component needs to execute a particular function, the process 
simply calls the function by its identifier. A layer of software residing within the 
client component, commonly referred to as a "client stub," traps the function call. If 
the client stub determines that the software code necessary to perform the called 
function actually exists within another server component, the client stub creates a 
message enclosing any data passed with the Junction call, as well as any necessary 
packetizing and addressing. The client stub, in one embodiment, then sends the 
message to the Server component via the real time operating system existing in the 
software system. The server module contains a layer of software code, known as the 
"server stub," that receives the message. The server stub strips apart the message 
and actually calls the correct local function with any data pulled from the message. 
The local function executes as if it were originally called locally, returning any 
information requested. The server stub creates a response based on the returned 
information, and sends the response to the client component via the operating system. 
Upon receipt of the response, the client stub pulls out the returned information and 
passes the information to the local software process that originally called the 
function. The local software process then continues unaware that any inter-module 
communication occurred. 

Component Definitions of One Embodiment of the Present Invention 

The following sub-sections provide details concerning the manner in which 
each base-class protocol can be implemented in an embodiment of medical imaging 
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system 10 of FIG. 1, in accordance with the present invention The sub-sections 
provide definitions and requirements of services provided by each of components 30, 
32, 22 and 24, 14 represented for purposes of illustration in the C++ object-oriented 
programming language, with comments included where appropriate. Where C++ 
5 code is used below to illustrate the functionality of a particular component, the label 
"host" may be used to refer to network client 12 and the label "laser imager" or "LI" 
may be used to refer to output imaging device 18. 

The Network Executive Base-Class Protocol 

The network executive base-class protocol, in this embodiment, includes one 
10 remote procedure call that network executive component 14 is required to provide 
for its client component, interface executive component 20. The remote procedure 
call is described below in terms of the types of parameters handled and the functions 
performed. 

1. setdebugjevel Parameters: Type: 

15 debug level DEBUG_LEVEL 

Returns: Type: 

void n/a 

The actual base class protocol for network executive component 14 can be 

defined in C++ code as follows: 

20 class NETWORX_EXECUTl VE { 
protected: 

LIINTERFACE *Ii_handle; // pointer to laser imager interface 

TNT32 return_code; // RC for OS operations 

DEBUGJJEVELS debugjevel; . //Debug level for module 
25 IMAGER_CONFIG *im_cfg; // imager/dicom configuration object 

public: 

NETWORK_EXECUTlVE(LI_INTERFACE *, IMAGER_CONFIG *); 
virtual ~NETWORK_EXECUTIVE(void); 

virtual void set_debugJevel(DEBUGJLEVELS level); //set to new debug level 

30 }; 

The base class protocol for a DI COM protocol-configured network executive 
component can be defined in C++ code as follows: 

class DICOM_EXEC : public TaskVStack, public NETWORK_EXECUTIVE{ 
friend class EVENTMGR; 
35 private: 

void execute(void); 

30 
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Bool init_network(); //initialize DIMSE interface to net 
int connectO; //monitor network and wait for a SCU 
Bool checkHeapSpaceO; //Check if enough heap for new SCU 
Bool checkHeapSpaceVerO; //Check if enough heap for new verify-only SCU 
5 public: 

int numConnections; 
int numConnectionsVer; 
Bool verification_only; 
int port; 

10 int networksocket; // socket for executive to listen to network 

int assocsockfd; // socket for new association 

DlMSE_nethandle netHandie; 

DICOMJ£XEC(LI_INTERFACE *, IMAGER_CONFIG *); 

~DICOM_EXEC(void); 
1 5 void async_handler(char, ID); 

//Asyncronous commands from Dicom Driver 

void set_debugJevel(DEBUG_LEVELS level); //set to new debug level 

}; 

20 In this example, the DICOM executive base class contains two remote procedure 
calls: set_debugjevel() and async_handler(). The async_handler() RPC allows a 
DICOM_Driver to inform the DICOM_executive that it has completed a task and 
should be shut down. 

The Network Driver Base-Class Protocol 

25 The network driver base-class protocol, in this embodiment, may include two 

remote procedure calls: set_debugjevel() and ni_event_handler(). The remote 
procedure calls are described below in terms of the types of parameters handled and 



the functions performed. 

1. setdebuglevel Parameters: Type: 

30 debug level DEBUGLEVEL 

Returns: Type: 

void n/a 

2. ni_event_handler Parameters: Type: 

Network Interpreter event NIJSVENT 

35 Returns : Typ e: 

void n/a 
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The ni_event-handler RPC receives asynchronous events from output imaging device 
18 that are propagated via network interpreter component 32, output interpreter 
component 22 and output driver component 24. 

As noted above, the network driver component 30 provides a mechanism for 
5 handling asynchronous events received from output imaging device 1 8. The events 
serve to inform network driver component 30 of a status change at output imaging 
device 18. Various events indicating the status of output imaging device 18 may 
include (1) NI_printer_update, which indicates that the output imaging device has 
changed it status, and (2) Nljrint job_update, which indicates an imaging job has 
10 changed its status. The function of the above status events is to avoid the need for 
the network client 12 to continuously poll output imaging device 18. 

The actual base class protocol for the network driver component 30 can be 
defined in C++ as follows: 

class NETWORKDRI VER { 
15 protected; 

INT32 return_code; // RC for OS operations 
ID assocjsocket; // socket descriptor for association 
lMAGER_CONFIG *imager_config; // Configuration information 
NETWORK_DRIVER(ID port, DEBUGJLEVELS,IMAGER CONFIG *) 
20 virtual ~NETWORKDRIVER(void); 

public: 

DEBUG_LEVELS debugjevel; //Debug level for module 
virtual void set_debugJevel(DEBUGJLEVELS level); //set to new debug level 
virtual void ni_event_handler(NI_EVENT,NI async data)=0 
25 }; ~ " ~ " - 

The base class protocol for a DICOM protocol-configured network driver 
component may make use of a DD_NET_MONlTOR object, which can be defined in 
C++ code as follows: 

class DD_NET_MONITOR : public TaskVStack{ 
30 private: 

DICOMJDRIVER ♦master; //pointer to controlling object 

void execute(void); //main execution thread 
public: 

DDJNET_MONITOR(DICOM_DRIVER *); 
35 ~DD_NET_MONITOR(void); 

}; 

typedef enum { / 
DD^PrinterStatusChange, 
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DDJobStatusChange 
} DDevent; 

The DD_NET_MONITOR is an object internal to a DICOM J)R1VER object that 
5 implements the DICOM driver component. The DDJsfETMONITOR object 
continuously monitors the network for incoming messages and informs the 
DICOM_DRIVER object upon their arrival. The DICOMJ5RIVER object then 
reads and processes the messages, passing any information to the 
DICOM JNTERPRETER object (network interpreter component 32) via RPC-based 
10 functions defined by the network interpreter component. 

The base class protocol for a DICOM protocol-configured network driver 
component can be defined in C++ code as follows: 

class DICOM_DRIVER : public TaskVStack, public NETWORKJDRIVER { 
friend class DD_NET_MONITOR; 
15 private: 

DD_NET_M0N1T0R network_jnonitor; //get messages from network 
//Association handling Methods and Parameters 
void associationServer(); //handle association 

void monitorNetwork(); //continually accept and valid DICOM messages int 
20 processMessage(); //handle the received DICOM message 
//FilmSession Methods and Parameters 

void handleFilmSession(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
void fsNCreate(DIMSE_CmdSet cmdSet, DIMSEJVfsgHandle msg); 
void fsNSet(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
25 void fsNAction(DIMSE_CmdSet cmdSet, DIMSEJVfsgHandle msg); 

void fsNDelete(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
//FilmBox methods and parameters 

void handleFilmBox(DIMSE_CmdSet cmdSet, DIMSE_MsgHandle msg); 
void fbNCreate(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
30 void fbNSet(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 

void fbNAction(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
void fbNDelete(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
//ImageBox methods and parameters 

void handleImageBox(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
35 void ibNSet(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 

//Annotation Box methods and parameters 

void handleAnnoBox(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
void abNSetpIMSE^CmdSet cmdSet, DIMSEJVlsgHandle msg); 
//Printer methods and parameters 
40 void handlePrinter(DIMSE_CmdSet cmdSet); 

void prNGet(DIMSE_CmdSet cmdSet); 
//Print Job methods and parameters 
void handIePrintfob(DiMSEj:mdSet cmdSet); 
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void pjNGet(DIMSE_CmdSet cmdSet); 
//Misc functions 

void async_event_server(); //server function called to process async events 
public: 

5 DICOM J)RIVER(DICOMJEXEC *,ID, DICOMJNTERPRETER * 
DIMSE_AssocHandle,DIMSE_SOPInfo *, 

DEBUG LEVELS, IMAGERCONFIG * )• 
~DICOM_DRIVER7void); 

void ni_event_handIer(NI_EVENT,NI_async data) 

10 }; 



In this example, the DIC0M_DR1VER includes a large number of functions that 
operate on incoming DICOM messages. Most of the functions can be rather 
DICOM-specific and will be apparent to those skilled in the art in view of the 

1 5 DICOM standard. Each of these functions is internal and is closely tied to related 
DICOM DIMSE commands. In addition, the D1COMJ3RIVER contains the RPC 
call that was specified in the network driver base class: ni_event_handler(). The 
DICOM functions ultimately call network interpreter-specific functions that use the 
RPC mechanism. 

20 The Network Interpreter Base-Class Protocol 

The network interpreter base-class protocol, in this embodiment, includes 
remote procedure calls that network interpreter component 32 is required to provide 
for its client component, network executive component 14. 

The actual base class protocol for network interpreter component 32 can be 

25 defined by the following C++ code in which the network interpreter is referred to as 
the "NETWORK INTERFACE": 

//Define asyncronous events for network interface 
typedef enum { 

NI_printer_update, // Announce that the LPs status has changed 
30 NI_printJob_update // Annouce that a print job's status has changed 

} NI_EVENT; 
typedef union { 

int id; // ID of component that has changed its status 
} Nl async data; 

35 typedef NETWORKDRIVER *ND_PTR; // pointer to ND client 
typedef void (NETWORK DRIVER: : *ND METHOD PTR) 
// pointer to client method 
(NIJEVENT, Nl_async_data); 
class NETWORK ^INTERFACE { 
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protected: 

INT32 return_code; // RC for OS operations 

ID port jd; // initial network port 

Semaphore rpcjreply; // RPC response complete 
5 Semaphore rpcjree; // RPC mailbox free 

Semaphore event_reply; // async event received 

Semaphore event free; // async event mailbox free 

Mailbox event_mbox; // event mailbox 

Mailbox rpcjnbox; // RPC mailbox 
1 0 ND_PTR driver; // driver module calling us 

NDMETHODPTR driver_async_handler; // pointer to async handler 

IMAGERCONFIG *iconfig; // pointer to imager configuration object 

NETWORK JNTERFACE(ID, LIINTERFACE * DEBUGJJEVELS, 
IMAGER CONFIG *); 
1 5 virtual -NETWORKJNTERFACE(void); 

LMNTERFACE *li_handle; // Handle to LI interface 

DEBUGJJEVELS debug Jevel; //Debug level for module 

Param_Blk parameters; // Pointer to parameters 

LI_async_data liasyncdata; // Data from LI events 

20 public: 

virtual Bool ILevent_handler(Ll_INTERFACE_EVENT,LI_async_data), 

virtual void set_asyncJunc(ND_PTR, ND_METHOD_PTR); 

virtual void set_debugJevel(DEBUG_LEVELS level); //set new debug level 

}; 

25 A base class protocol for a DICOM protocol-configured network interpreter 

component can be represented by the following C++ code: 

// DICOM Interface Message type for RPCs 
typedef struct { 

DICOM_Command command; // DICOM command/event to execute 
30 DICOMResponse "response; // Pointer to response object 
DICOMData data, // message data 
} DICOMJVIessage; 

class DICOM JNTERFACE : public TaskVStack, public 
NETWORK JNTERFACE, 
35 public PrintServerlnf, public SessionHandler { 

private: 

DICOM_Message *message; // Pointer to RPC client message 
DICOM JResponse *response; //Pointer to response object 
DICOMJData *data; // message data 
40 INT32 return_code; // rpc return code 

PrinterStatus currentPrStatus; 
void execute(void); 

void send_rpc(DICOM_Message *); // Send msg to server thread 
void ack_rpc(void); // Acknowledge RPC completion 

45 public: 

DICOM JNTERFACE(ID, LI JNTERFACE *, DEBUG^LEVELS, 

35 



IMAGERCONFIG •); 
-DICOMJNTERFACE(void); 

Bool H_event_handIer(LI_INTERFACE_EVENT, LI_async_data); 
// Async event handler 

); 

class PrintServerlnf : public BasePrintServer { 
public: 

// Constructor - initialize the data members and establish 
// a connection with the PrintServer process. 
PrintServerInf(DICOM_INTERFACE*, IMAGER_CONFIG*); 
// Destructor - cleanup session and memory dynamically allocated 
-PrintServerlnfO; 

// This method opens a film session at the PrintServer and 

// returns a pointer to a FilmSessionlnf object. 

FilmSessionlnf* openSessionQ { return openSession(StringO); } 

FilmSessionlnf* openSession(const String& origld); 

// This method closes the session at the PrintServer, resulting 

// in the deletion of all images previously stored in the session 

// and all the open film boxes. 

void c!oseSession(); 

// This method gets the status information of a job specified by its id. 
bool getJobStatus(JobStatus& status, ID jobld); 
// The following methods allows a client to manipulate jobs on the 
// Print Server queue. 

// This method removes a job from the server's queue, 
bool cancel(ID jobld); 

// This method changes the priority of a job in server's queue, 
bool alterPriority(ID jobld, Priority p); 

// This method returns an object containing printer status information 
bool getPrinterStatus(PrinterStatus& status); 
// This method notifies the server to shutdown, 
void shutdownO; 

void setHostName(const String& name); 
void setHostName(char* name); 
protected: 

void connectO; 

bool getPrintQueue(JobIdArray& jobs, ID sessionld, const String& origld); 
DICOMJNTERFACE* master; 
IMAGER_CONFIG *m_config; 

private: 

FilmSessionlnf* m_fs; 

}; 

class SessionHandler { 

friend class DICOM_INTERFACE; 

public: 

DICOMJNTERFACE* master; 
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ID msessionld; 

ID mjbld; 

ID m_imgld; 

LIST mj>rintJobs; 

Bool m_contrastTest; 

int rnjmages_acquired; 

LSVRStatus m_acquire_status; 

States m_state; 

String hostName; 

Bool m_contrastTestMode; 

PARAMETERS mjiparams; 

IMAGE *image_Iist[MAX_IMAGES_PER_PAGE]; 

IMAGE image Jist_store[MAXJMAGESJ>ERJ> AGE]; 

IMAGE *raw jmage Jist[MAX_IMAGES_PER_P AGE] ; 

IMAGE rawJmageJist_store[MAXJMAGES_PERJPAGE]; 

SessionHandier(DICOM__INTERFACE* m); 

virtual -SessionHandlerQ; 

ID getSessionId(); 

ID getNextFilmBoxIdO { return ++m Jbld; } 

ID getNextlmageldO { return -H-mJmgld; } 

Bool queryPrintTobs(ID jobld) { return mj)rintJobs.query(jobId); } 

void mapJobStatus(JobStatus* js); 

Bool hand!eContrastTestEvent(char* nid); 

void printContrastTest(ID image); 

LSVR_Status acquireAllImageMemory(int rows, int cols); 

void sessionClientHandler(); 

void openSessionHandlerQ; 

void closeSessionHandlerO; 

void newFilmBoxHandlerQ; 

void printHandlerO; 

void imageAlIocateHandIer(); 

void imageDataHandlerO; 

void deleteImageHandler(); 

void filmAttrHandlerO; 

void imageAttrHandler(); 

void associatelmageHandlerO; 

void eraselmageHandlerQ; 

void eraseAMImagesO; 

void deleteFilmBoxHandlerO; 

void getPrinterStatusHandlerQ; 

void getPrintQueueO; 

void getJobStatusHandlerO; 

void canceJobHandlerO; 

void setPriorityHandlerO; 

void noImageHandlerQ; 

void errorHandlerO; 

void cleanUpImagesQ; 
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void updateParameters(BaseFilmSession *fs, BaseFilmBox *fb); 

}; 

The Output Interpreter Base-Class Protocol 

5 The network interpreter component 32 interfaces with output interpreter 

component 22 via a set of imaging objects; The imaging objects serve as parameters 

for the remote procedure calls and contain all of the available information concerning 

the characteristics of output imaging device 18 and the imaging process. The 

network interpreter component 32 can use any part of the information and disregard 

10 the rest. There are six imaging object definitions including (1) a box object, (2) a 

format object, (3) an image object, (4) a test image object, 5) a string object, and 6) a 

variety of general imaging parameter objects. 

A format object is used to describe an entire sheet of imaging media on which 

output imaging device 18 will form an image. The format object holds information 

15 relating to film type, film size, border color, border density, etc. The charactersitics 

of the format object can be defined in C++ as follows: 

class FORMAT { 
public: 

FORMAT(FORMATJD); //Constructor 

20 FORMAT(void); // Constructor 

void init(void); // Initialize parameters to defaults 

FORMATTED id; // Format to which this box belongs 

TABLE bkgnd_colorjable; // Background/border color media table 
TABLE bkgnd_colorjnixing_table;// Background/border color mixing table 

25 LEVEL bw_borderJevel; // B&W border level 

COLOR color_brdJevel; // Border Color levels 

LEVEL bw_density_max; // B&W maximum density 

FILMJT YPE film Jype; // Type of film to use 

FILM_SIZE filmsize; // Size of film to use 

30 }; 

A box is a rectangular area of the film sheet designated to hold an image. The 

box has many characteristics including location, size, contrast, color, etc. The box 

definitions are associated with a particular format. That is, several boxes are used in 

conjunction with a particular format. The following C++ code describes the box 

35 object and its characteristics: 

class BOX { 
public: 

BOX(BOX_ID id,FORMAT_ID id); // Constructor 
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BOX(void); 
void init(void); 
BOX JD id; 

FORMAT JD format Jd; 
TABLE beta_xl; 
TABLE beta_yl; 
TABLE beta_x2; 
TABLE beta_j2; 
TABLE colormediajable; 
TABLE contrast Jable; 
TABLE colorcontrastjable; 
TABLE color jnixingjable; 
FRAME frame; 
LOCATION xjocation; 
LOCATION yjocation; 
Switch mirroring; 
Switch rotation; 

OUTPUT_SIZE output_size_xl 
OUTPUT SIZE output_size__yl 
OUTPUT_SIZE output_size_x2; 
OUTPUT_SIZE output_size_y2 
OFFSET window_x_offset; 
OFFSET window_yoffset; 
LENGTH window_xJength; 
LENGTH window_y_Iength; 



}; 



// Constructor 

// Initialize parameters to defaults 
. //Box id # 
// Format the box 
// Horizontal axis beta pass 1 
// vertical axis beta pass 1 
// Horizontal axis beta pass 2 
// Vertical axis beta pass 2 
// Color media table to use 
// B&W contrast table to use 
// Color contrast table to use 
// Color mixing table to use 
// Frame to use around border 
// Horizontal pixel location 
// Vertical pixel location 
// Turn mirroring on and off 
// Turn rotation on and off 
// X output size pass 1 
// Y output size pass 1 
// X output size pass 2 
// Y output size pass 2 
// Window X offset from corner 
// Window Y offset from corner 
// Horizontal length of window 
// Vertical length of window 



An image is represented by image data containing digital image values. The 

image data is stored in an image memory associated with output imaging device 1 8. 

The image object is used to associate certain characteristics with the image. As 

indicated by the above code, the characteristics may include pixel length, pixel width, 

pixel depth, color format, etc. When printing, an image is used to fill the boxes 

defined for the format that is to be used. The following C++ code describes the 

image object and its characteristics: 

class IMAGE { 
public: 

IMAGE(void); 

IMAGE(IMAGE_ID id); 

void init(void); 

IMAGE JD id; 

COLORFORMAT mode; 

LENGTH xjength; 

LENGTH yjength; 

DEPTH image _depth; 



// constructor 
// constructor 

// Initialize parameters to defaults 
// Identification Number 
//color image format 
// horizontal image length in pixels 
// vertical image length in lines 
// depth of image 8-12 bits 
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); 



DURATION timeout; 
Switch permanent; 



// acquire timeout for this image 
// image will be held for a while 



A test image object is used to symbolize images used for testing purposes. 

the images are software generated and have different attributes than an image. The 

following C++ code describes the test image object and its characteristics. 

class TESTJMAGE { 
public: 

TESTJMAGE(void); 

TEST_IMAGE(IMAGE_ID id); 

void init(void); 

IMAGEJD id; 

COLOR_FORMAT mode; 

LENGTH xjength; 

LENGTH yjength; 

DEPTH image_depth; 

DURATION timeout; 

TEST_IMAGE_TYPE imagejype; 

LEVEL red_density; 

LEVEL green_density; 

LEVEL blue_density; 



); 



// constructor 
// constructor 

// Initialize parameters to defaults 
// Identification Number 
// color image format 
// horizontal image length in pixels 
//vertical image length in lines 
// depth of image 8-12 bits 
// acquire timeout for this image 
// type of test pattern 
// Constant density - red density; 
// Constant density - green density; 
// Constant density - blue density; 



A string object is used to hold ASCII text in the image memory. The string 

object also allows the use of parameters such as length, intensity, type, etc. The 

following C++ code describes the string object and its characteristics: 

class STRING { 
public: 

STRING(void); 

STRING(IMAGEJD id); 

void init(void); 

STRINGJD id; 

TEXTTYPE type; 

char *text; 

LEVEL bw_foregnd_intensity; 
LEVEL bw_backgnd ^intensity; 
COLOR colorjbregnd ^intensity; 
COLOR color backgnd intensity; 
LENGTH width; 
LENGTH lead; 

}; 



// constructor 
// constructor 

// Initialize parameters to defaults 
// id of string 
//Type of the text 
// string 

// B&W forground intensity 
// B&W forground intensity 
// Color foreground intensities 
// Color background intensities 
// width of string 

// # of blank lines between ASCII lines 
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The general parameters object is used to hold all process configuration 

parameters. This object can be used to set the parameters in the laser imager, or to 

read the current settings of the parameters. Examples of some parameters are default 

beta tables, default color contrast, default destination, default film size and type, etc. 

5 A few parameters are read-only, and thus cannot be set, such as the amount of 

memory available, the current software revision, the total prints queued, etc. The 

following C++ code describes the general parameter object and its characteristics. 

class PARAMETERS { 
public: 

1 0 PARAMETERS(void); 

void set_defaults(void); 

DURATION acq_timeout; 

TABLE defbetajcl; 

TABLE def_beta_yl; 
15 TABLE defbeta_x2; 

TABLE defbeta_y2; 

LEVEL def_bw_border; 

COLOR defcplorJ>order; 

COLORJFORMAT defcformat; 
20 TABLE defbw_contrast; 

TABLE def_color_contrast; 

TABLE def_colorjnix; 

LEVEL def_max_density; 

DEPTH def_depth; 
25 DESTINATION def_destination; 

LEVEL defbwdmax; 

IMAGETYPE defjmagejype; 

FILMJTYPE deffilmjype; 

FILM_SIZE def_filmj>ize; 
30 LENGTH def_image_xsize; 

LENGTH def_image_ysize; 

Switch fixed_formatting; 

FIXED FORMAT fixedjbrmat; 
/** Read only parameters **/ 
3 5 long int fixed_image_pattern; 

MEMORY memory; 

OP JVIODE op_jnode; 

RELEASE revision; 

SYSTEM system; 
40 int total_queued; 

int totalcompleted; 

int total_failed; 

}; 



// Constructor 

// Initialize to defaults 

// Acquisition timeout 1.. 65535 seconds 

// Default horizontal axis beta pass I 

// Default vertical axis beta pass 1 

// Default horizontal axis beta pass 2 

// Default vertical axis beta pass 2 

// Default B&W Border level 

// Default color border level 

// Default acquisiton image format 

// Default contrast table while in B&W 

// Default contrast table while in color 

// Default mixing table while in color 

// Default maximum density value 

// Default bits per pixel 

// Default destination for print images 

// Default B&W maximum density value. 

// Default acceptible image type 

// Default media type 

// Default media size 

// Default width of image in pixels 

// Default length of image in lines 

// Switch for fixed formatting 

// Fixed format number 

// Image acquisition pattern 
// Memory status structure 
// Operational mode 
// Current revision 

// Imaging system of the Laser Imager 
// Total prints queued in the system 
// Total prints completed in current jobs 
// Total prints failed in current jobs 
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One of the major responsibilities of output interpreter component 22 is to relay the 
status of the output imaging device 18 to the client component, network intrepreter 
component 32. The status relay process has two steps. When output interpreter 
component 22 notes a status change in output imaging device 18, the event handler in 
5 the client component is called directly by the output interpreter component. The 
event handler is passed a status event. The possible status events include (1) the 
FP_status_change, (2) the PR_status_change, (3) the IMS_status_change, (4) the 
JOB_status_change, and (5) the XFR_status_change. The output interpreter 
component 24 notifies the client, network interpreter component 22, of the above 

10 status changes, so that the network interpreter component does not need to 
continuously poll the laser imager. 

It is the responsibility of the client, network interpreter component 32, to 
either ignore the status change or request further information. All status information 
is contained within five status objects. There is status object for the film processor, 

15 the printer, the image management system, jobs, and background jobs (transfers). 

Each status object has a status field which can be easily checked to see if warnings or 
errors exist. If warnings or errors exist, further examination of the warnings 
structure or the error structure can be done. Again, the client can choose to use only 
the information it needs. The following C++ code shows the definition for each of 

20 the status objects and the structures they contain: 

/**Film Processor Status object typedefs and class definition **/ 

class Film_Processor { 

public: 

Film_Processor(void); // Constructor 

25 void clear(void); // clears status object 

intid; //Id 

int WarmingTime; // Time till warm 

FPJType type; // Film Processor Type 

FP_Status status; // Film Processor status 

30 FPWarnings warnings; // current warnings in Film Processor 

FPJErrors errors; // current errors in Film Processor 

}; 

typedef enum { 

Antares_FP, // Antares film processor. 

35 LT_SE154_FP // LT film processor. 

No_FP, // No film processor connected. 

Spectrum_FP // Spectrum film processor. 

42 



WO 98/15092 



PCT/US97/17407 



} FPJType; 
typedef struct { 

unsigned Busy : 1; 

unsigned NoFP : 1; 
5 unsigned OpenLoop : 1; 

unsigned Ready : 1; 

unsigned Warming : 1; 

unsigned Warnings : 1; 

unsigned Errors : 1; 
10 } FP_Status; 
typedef struct { 

unsigned CheckChem : 1; 

unsigned Generic : 1, 

unsigned HiOvf : 1; 
15 unsigned LoChem : 1; 
} FP_Warnings; 
typedef struct { 

unsigned FPDown : 1; 

unsigned FullOvf : 1 ; 
20 unsigned Generic : 1; 

unsigned MediaJam : 1; 

unsigned OutChem : 1 ; 
} FP_Errors; 



// Processor is in clean-up or busy with media 

// No film processor docked 

// Not doing calibration 

// Ready to process film 

// Warming up 

// Warnings exist 

// Errors exist 



// Chemistry is getting bad. 
// Miscellaneous 

// One or more overflow tanks is getting high 
// One or more chemistry tanks is getting low 



// Processor is not operational 

// One or more overflow tanks are full 

// Miscellaneous 

// Media jammed in the film processor 

// One or more film chemistry tanks are empty 



25 
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/**Image Managment System Status object typedefs and class definition**/ 

class Image_Mgmnt_System { 

public: 

Image_Mgmnt_jSystem(void); // Constructor 



void clear(void); 
IMS status status; 
IMS_errors errors; 

}; 

typedef struct { 

unsigned PowerUp : 1; 

unsigned Errors : 1; 
} IMS_status; 
typedef struct { 

unsigned BadConfig : 



// clears status object 

// Image Management System status 

// current errors in Image Management System 



// First status since it has been powered up, 
// Errors exist in the system 



1; 



// IMS is configured improperly 
unsigned BadTblEprom : 1; // Table EPROMS have an incorrect checksum 
unsigned IMNVRamErr : \ jl Non volatile ram error in an input module 
unsigned IMSDown :!;■// IMS is not operational, 
unsigned OMNVRamErrl : 1; //Non volatile ram error in output module 1 
unsigned OMNVRamErr2 : 1; //Non volatile ram error in output module 2 
unsigned MemBlkErr : 1; // 10% or more of image memory is bad 
} IMS_errors; 



/ 



Printer Status object typedefs and class definition 



**/ 
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class Printer { 
public: 

Printer(void); 

void clear(void); 

int id; 

int SheetsRemaining; 
FILM_TYPE MediaType; 
FILM_SIZE MediaSize; 
int lmgPixels; 
int ImgLines; 
Quality quality; 
PRjype type; 
PR_status status; 
PR_warnings warnings; 
PR_errors errors; 

}; 

typedef struct { 

unsigned Warnings: 1; 

unsigned Errors : 1; 
} PRstatus; 
typedef enum { 

Draft, 

Photo 
} Quality; 
typedef enum { 

SpectrumJPR, 

AntaresJ'R, 

LT_SE154 PR, 

No_PR, 

XLPR 
} PRjype; 
typedef struct { 

unsigned MediaLow : 1; 



unsigned Busy 
unsigned PrCalib 

} PRwarnings; 

typedef struct { 
unsigned BadCass 
unsigned CassErr 
unsigned CassJam 
unsigned CoverOpen 
unsigned ExpJam 
unsigned MediaOut 
unsigned NoCass 
unsigned PanelErr : 
unsigned PrDown 



i; 
i; 



i; 
:i; 
i; 
i; 



// Constructor 

// clears status object 

//Printer Id 

//# of sheets left 

// Type of film loaded 

// Size of film loaded 

// # of imageable pixels 

// # of imageable lines in media 

// Current quality condition 

// Printer Type 

// Printer status flags 

// current warnings in Printer 

// current errors in Printer 



// Warnings exist in the system 
// Errors exist in the system 



// Spectrum printer. 
// Antares printer. 
//LT printer. 
// No printer connected 
// XL (Roadrunner) printer 



// Media is low (less than 20 sheets). 
// The printer has a transient problem. 
// Printer is generating a calibration sheet. 



unsigned RecMagFull : 1; 



// Media cassette is inoperable. 

// Cassette error occurred. 

// Media jam at cassette. 

// One of the covers is open. 

// Media jam at exposure point. 

// No media in printer. 

// No media cassette in printer. 

//Printer LCD panel in non operable 

// Printer is not operational 

// The Rec Magazine is full and needs to be emptied. 
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unsigned RecMagMiss : 1; // The Receive Magazine is not in the printer, 

unsigned ToExpJam : 1; // Media jam transporting to exposure point, 

unsigned ToProcJam : 1; // Media jam transporting to film processor. 
} PR_errors; 



/** Job Status object typedefs and class definition 
class Job { 
public: 

Job(void); 
10 void clear(void); 

int id, 

int PrintsComplete; 
int PrintsFailed; 
int PrintsQueued; 
15 int FilmsComplete; 
int FilmsFailed; 
int FilmsQueued; 
JOB_status status; 
JOBerrors errors; 

20 }; 

typedef struct { 

unsigned Done : 1; 

unsigned Killed : 1; 

unsigned Stopped : 1 ; 
25 unsigned Wait : 1; 

unsigned Errors : 1; 
} JOBstatus; 
typedef struct { 

unsigned Aborted 
30 unsigned BadBand 

unsigned BadMedia 

unsigned BadTable 

unsigned CrossPrtErr : 

unsigned FPErr : 1 
35 unsigned ImgAbut 

unsigned IMSErr : 1 

unsigned LinePixelErr : 

unsigned MaxBadCnt 

unsigned MaxBandlmg 
40 unsigned MaxHorlmg 

unsigned MinBand 

unsigned Parity : 1; 

unsigned PrErr : 1; 

unsigned RecMagErr 
45 unsigned WrongQual 
} JOB_errors; 



/ 



// Constructor 
// clears status object 
//JOB Id 

// # prints printed properly 
// # prints printed improperly 
// # prints waiting to be printed 
// # sheets printed properly 
// # sheets printed improperly 
// # sheets waiting to be printed 
//JOB status 
// current errors in JOB 



// Job is complete 
// Job was killed 
// Job was stopped 
// Print is in print queue 
//Job has errors 



1; 
1; 

:i; 
i; 
1; 



// Abort command issued 
// Images not contained in a single band 
// Media not available. 
// Invalid table specified 
// Illegal configuration* 
// Film processor has failed. 
// Images illegally abut each other 
// Images illegally abut each other 
// Too many pixels 
: 1 ; // Two identical errors 
: YJI max images per band 
: 1;// max horizontal images 
1 ; // Fewer than min lines per band 
// Parity error within an image 
// Printer has failed 
\\ II Receive Magazine missing or foil. 
; 1; // Quality not available 



l; 



i; 
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/** Transfer Job Status object typedefs and class definition 
class Xfr { 
public: 

Xfr(void); 
5 void clear(void); 

int id; 

Length Xsize; 
Length Y_size; 
XFR_status status; 
1 0 XFRerrors errors; 

}; 

typedef int Length; 
typedef struct { 
unsigned Wait : 1; 
15 unsigned Done : 1; 
unsigned Killed : 1; 
unsigned Errors : 1; 
} XFR_status; 
typedef struct { 
20 unsigned Aborted : 1 ; 
unsigned AcqErr : 1; 
unsigned BadDepth : 1 ; 
unsigned BadMode : 1; 
unsigned ConnectErr : 1 ; 
25 unsigned EibParamErr : 1 ; 
unsigned EibSrcErr : 1; 
unsigned EibTranErr : 1; 
. unsigned FifoErr : 1; 
unsigned MemBoundErr : 
30 unsigned MemErr : 1; 
unsigned MemFull : 1; 
unsigned NVRamErr 
unsigned ParityErr : 1 ; 
unsigned ResErr : 1; 
35 unsigned SetUpErr : 1; 
unsigned SizeErr : 1 ; 
unsigned TimeOut : 1; 
} XFR_errors; 

The output interpreter component 24, in this embodiment, provides fifteen 
40 types of remote procedure calls. With the use of the above described imaging objects 
and the remote procedure calls, the client can fully operate output imaging device 18. 
Note that all of the parameters contained in the imaging objects described above are 
initialized to an "unassigned value". If the parameter is not changed by the client, the 
output interpreter component 24 will ignore it. This feature allows the client to use 



// Constructor 

// clears status object 

//JOB Id 

// Horizontal image size (if job complete) 
// Vertical image size (if job complete) 
//JOB status 
// current errors in JOB 



// Job is in queue 
// Job is complete 
// Job was killed 
// Job has errors 



// Abort command issued 
// Acquisition error. 
// The depth specified cannot be set. 
// Incorrect current mode. 
// Connection error 
// Bad parameter in NVRAM 
// Bad source value in NVRAM 
// Error while translating EIB parameters 
// FIFO overflow 
1 ; // Outside boundary of available memory 
// Memory error during store 
// Image memory is full 
1; // Misc error with NVRAM 
// Parity error 

// store to reserved memory failed 
// Configuration error 
// Image size error 

// System timed out during image store 
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only the parameters that it needs. Each of the remote procedure calls provided by 
output interpreter component 24 is described below. Unless otherwise indicated, the 
return for each of the following remote procedure calls is a Laser Imager Response 
Object of type LIresponse, which will be further described later in this disclosure. 
5 1. Media Print RPCs 

a. print Parameters: Type: 

copies (opt) int 
The above RPC initiates a general print from a laser imager functioning as output 
imaging device 18. The above RPC is designed to be used with fixed-formatting. 
10 The format is a currently selected fixed format. Copies is an optional parameter 
indicating the number of copies to produce. The images that have been acquired 
since the last print will be used for the print. 



b. print Parameters: Type: 

format int 

15 image list LIST 

copies (opt) int 

density (opt) int 

destination (opt) DESTINATION 



The above RPC initiates a print from the laser imager. Format is the format ID to 
20 use. Image list indicates which images to use to fill the format. Copies is an optional 
parameter indicating the number of copies to produce. Density is an optional integer 
which is used when a density test patch is desired. The integer value corresponds to 
an image ID. Destination is an optional parameter that defines a destination for the 
output rather than the default. 



25 c. print_test Parameters: Type: 

format int 

image list LIST 

densjd IMAGE JD 



copies (opt) int 

30 destination (opt) DESTINATION 

The above RPC initiates a print from the laser imager. Format is the format ID to 
use. Image list indicates which images to use to fill the format. Densjd is an integer 
that represents the image id of a density test patch. Copies is an optional parameter 
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indicating the number of copies to produce. Destination is an optional parameter 
which defines a destination for the output rather than the default. 

d. abort Parameters: Type: 

job ID JOB ID 

5 The above RPC aborts a job having the corresponding id. 

e. abort Parameters: Type: 

none n/a 
The above RPC aborts all jobs that have been started. 
2. Formatting RPCs 
10 a. define Parameters: Type: 

format object FORMAT 
The above RPC defines a format with the exact parameters as found in the format 
object. All parameters equal to NOTAS SIGNED are not included in the definition. 

b. define Parameters: Type: 
15 box object BOX 

The above RPC defines a box with the exact parameters as found in the box object. 
All parameters equal to NOT_ASSIGNED are not included in the definition. 

c. modify Parameters: Type: 

box object BOX 
20 The above RPC modifies the box that matches the id specified in the box object. All 
parameters equal to NOT_AS SIGNED in the box object are not modified. 

d. modify Parameters: Type: 

box object BOX 
x_shift LENGTH 
25 y_shia LENGTH 

The above RPC modifies the box that matches the id specified in the box object. The 

location of the box is shifted by the amounts specified in x_shift and y_shift. All 

parameters equal to NOT ASSIGNED in the box object are not modified. 

e. modify Parameters: Type: 

30 format object FORMAT 

The above RPC modifies the format that matches the id specified in the box object. 
All parameters equal to NOTASSIGNED in the format object are not modified. 
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f. remove Parameters: Type: 

none n/a 
The above RPC deletes the last image acquired. 

g. remove Parameters: Type: 

5 box object BOX 

def(opt) Bool 
all (opt) Bool 

The above RPC deletes the box with an id matching that of the received BOX object. 

DEF is an optional parameter that when set to TRUE causes the job to be deferred 

10 and processed in the background. If not received, DEF is set to FALSE. ALL is an 

optional parameter that when set to TRUE causes all defined boxes to be deleted. If 

not received, ALL is set to FALSE. 



h. remove Parameters: Type: 

format object FORMAT 

15 def(opt) Bool 

all (opt) Bool 



The above RPC deletes the format with id matching that of the received FORMAT 
object. DEF is an optional parameter that when set to TRUE causes the job to be 
deferred and processed in the background. If not received, DEF is set to FALSE. 
20 ALL is an optional parameter that when set to TRUE causes all defined formats to be 
deleted. If not received, ALL is set to FALSE. 



i. remove Parameters: Type: 

image object IMAGE 

def(opt) Bool 

25 all (opt) Bool 



The above RPC deletes the image with id matching that of the received IMAGE 
object. DEF is an optional parameter that when set to TRUE causes the job to be 
deferred and processed in the background. If not received, DEF is set to FALSE. 
ALL is an optional parameter that when set to TRUE causes all defined images to be 
30 deleted. If not received, ALL is set to FALSE. 

j. remove_all Parameters: Type: 
def (opt) Bool 
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The above RPC deletes all images, boxes, formats and tables defined in the laser 
imager, DEF is an optional parameter that when set to TRUE causes the job to be 
deferred and processed in the background. If not received, DEF is set to FALSE, 
h. remove_fixed_image$ Parameters: Type: 

5 none n/a 

The above RPC deletes all images stored via fixed format store RPCs. 
3. Image Manipulation RPCs 

a. store Parameters: Typ e: 

none n/a 
10 This remote procedure call is strictly used with fixed formatting. This remote 

procedure call acquires the next image into the next available fixed image location. 
The locations range from 1 to N where N is the format specific. 

b. store Parameters: Type: 

id FIXEDJD 
15 This remote procedure call is strictly used with fixed formatting. This remote 
procedure call acquires the next image into the location specified by id. The 
locations range from 1 to N were N is the format specific. 

c. store Parameters: Type: 

image IMAGE 
20 The above RPC acquires the next image. The return information regarding image 
size is placed in LIresponse. 

d. store Parameters: Type: 

image TESTJMAGE 
The above RPC acquires the next image as a test pattern. The return information 
25 regarding image size is placed in LI_response. 

e. store Parameters: Type: 

string STRING 
The above RPC stores the text and the id in the STRING object. This allows the 
client component to recall the text at any time via the id. The return information 
30 regarding string size is placed in LI_response. 

f transfer Parameters: Type: 
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image IMAGE 
The above RPC transfers the next image as a background job. The return 
information regarding image size is available when image transfer is complete, 
g. reserve Parameters: Typ e: 
5 image IMAGE 

The above RPC allocates enough image memory to hold the image described by the 
IMAGE object. 

4. Process Configuration / Status RPC 

a. set Parameters: Type: 

10 parameter object PARAMETER 

The above RPC sets the imaging parameters for the laser imager. All parameters set 
to NOT_ASSIGNED will be left unchanged. 

5. Status RPCs 

a. show Parameters: Type: 

1 5 parameter object "PARAMETER 

The above RPC retrieves the imaging parameters for the laser imager. 

b. show_fixed Parameters: Type: 

parameter object "PARAMETER 
The above RPC retrieves the fixed formating imaging parameters for the laser imager. 
20 All other members in the parameter object are left unchanged. All other members in 
the parameter object are left unchanged. 

c. showmem Parameters: Typ e: 

parameter object "PARAMETER 
The above RPC retrieves the memory conditions of the laser imager. 
25 d. show Parameters: Type: 

image object "IMAGE 
The above RPC retrieves the length and width of the image with id matching the id 
given in the image object. All image information is placed in the image object, 
e. show Parameters: Type: 

30 printer object "PRINTER 
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The above RPC retrieves the status of the printer with id matching the id given in the 
printer object. All printer information is placed in the printer object. 
£ show Parameters: Type: 

job object *JOB 
5 The above RPC retrieves the status of the job with id matching the id given in the job 
object. All job information is placed in the job object. 

g- show Parameters: Type: 

printer object *XFR 
The above RPC retrieves the status of the transfer job with id matching the id given 
1 0 in the transfer job object. All transfer job information is placed in the transfer job 
object. 

h. showformats Parameters: Type: 

string *char 
The above RPC retrieves a string of id's of the defined formats. 
15 i. showjmages Parameters: Type: 

string *char 
The above RPC retrieves a string of id's of the acquired images, 
j. show_con_tabIes Parameters: Type: 

string *char 
20 The above RPC retrieves a string of id's of the defined contrast tables. 

k. showconjables Parameters: Type: 

string *char 
The above RPC retrieves a string of id's of the defined color contrast tables. 
I. set_debug_level Parameters: Type: 
25 debug level DEBUGJJEVEL 

Returns: Type: 
Driver return code DRIVERRC 
The above RPC allows the client component to set the debug level of network 
interpreter component 32. The debug levels are NO J)EBUG, LOWJDEBUG, 
30 MEDIUMDEBUG, and HIGH_DEBUG. This parameter affects the information 
displayed during debugging. 
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One advantage of the interface to output interpreter component 22 is that 
every remote procedure call returns a similar object. This object is called, most 
appropriately, the laser imager response object, as indicated above. Within the laser 
imager response object is a plethora of information regarding the result of the remote 
5 procedure call. However, the client may choose to examine only the information 
relevant to its needs. The laser imager response object has three main fields. The 
first is a simple boolean value entitled success. The boolean value reflects whether 
the request associated with the remote procedure call was accomplished or whether it 
failed. This information may satisfy the needs of most client components. The 

10 second field, success_data, returns any values that the client component expects if the 
command was successful. Normally, there will not be any information for a 
successful command. However, one example of information returned for a successful 
command would be the image size that is returned after a successful store image 
command. The third field, errors, is used to explain why the remote procedure call 

1 5 failed. This field is actually a comprehensive bit field of errors that the laser imager 
may incur. Again, this field is only valid if success is false. 

The C++ code listed below describes the laser imager response object. The 
class defines the response received from the laser imager after a command has been 
issued. If the command executed successfully, the SUCCESS flag is set to TRUE. 

20 Any data that is received upon a successful completion will be stored in 

Success_Data. If the command failed, the SUCCESS flag is set to FALSE. The 

cause of the failure is stored in the Failures structure 

class LI j-esponse { 
friend SSJEXECUTIVE; 
25 Command cmd; // SS command 

public: 

LI_response(void); // constructor 

Bool success; // Command executed to completion 

SuccessJData success_data; // Only valid upon successful completion 
30 Failures errors; // If command failed, errors causing failure 

}; 

typedef struct { 

unsigned AcqErr : 1 ; // Acquistion Error 

unsigned AcqLockout : 1 

35 unsigned BadBoxId : 1 

unsigned BadDepth : 1 



// Acquistion never attempted, not available 
// Box ID does not exists for modification 
// Pixel depth error 
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10 
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unsigned BadFmtld 
unsigned BadPar : 1; 
unsigned BadCConTbl 
unsigned BadCMediaTbl 
unsigned BadConTbl 
unsigned BadCMixTbl 
unsigned BadDensTest 



l 



unsigned BadDest 
unsigned Badlmgld 
unsigned BadJobld 
unsigned BadMedia 
unsigned BadMode 
unsigned BoxInUse 
unsigned Busy : 1; 
unsigned CConlnUse : 1 ; 
unsigned ConlnUse : 1; 
unsigned ConnectErr : 1; 
unsigned EibParamErr : 1; 
unsigned EibSrcErr : 1; 
unsigned EibTranErr : 1; 
unsigned Empty : 1; 
unsigned FifoErr : 1; 
unsigned FmtFull : 1; 
unsigned FmtlnUse : 1 ; 
unsigned FmtOvrLap : 1; 
unsigned FmtOffSheet : 1; 
unsigned FmtTMCon 
unsigned FmtTMCCon 
unsigned FmtTMCMix : 1; 
unsigned FmtTMCMedia : 1; 
unsigned FmtTMlmgs 
unsigned Full : 1; 



: 1; // Format ID does not exist 

// Bad Parameter 
: 1 ; // Bad Color Contrast Table 
: 1 ; // Bad Color Media Table 
: 1; //Bad Contrast Table 
: 1 ; // Bad Color Mixing Table 
: 1; // Image is not a valid density test patch 

// Invalid destination 
: 1 ; // Image was not found 
: 1 ; // Job was not found 
: 1 ; // Media type correct 
: 1 ; // Incorrect input mode (color / b&w) 
// Box is currently being used 
// Module is already doing an image transfer 
// Color Contrast table currently being used 
// Contrast table is currently being used 
// Hardware connection problem 
// EIB parameter error 
// Invalid EIB source 
// EIB transfer parameters invalid 
// Mbox is currently empty 
//FIFO overflow 

// would be more than 255 boxes in a format 
// Format currently being used 
// The boxes in this format overlap 
// box in this format will not fit on media 



i; 
i; 



i; 



// Too many contrast tablesin this format 
// Too many color cont tables in this format 
// Too many color mix tables in this format 
// Too many color med. tables in this format 
// Too many images specified in image list 



//MBOX is full 



unsigned InModlnUse : 1; // Input Module is currently being used 



unsigned ImglnUse 
unsigned Imglnvalid 
unsigned JobDone 
unsigned MagErr 
unsigned MaxFmts 
unsigned MaxJobs 



1 ; // Image is currently being used 
1 ; // Image has not been fully stored yet 
1 ; // Job has already terminated 
1 ; // Magnification error 
: 1 ; // There would be more than 255 formats 
I ; // Would exceed max # concurrent jobs 
unsigned MemBoundErr : 1; // Invalid image memory address 
unsigned MemErr : 1 ; // Memory error occured during store 
1 ; // Image Memory is full 
1 ; // Missing Parameter 

1 ; // Move would cause box location to become neg. 
: 1 ; // Not enough memory to execute command 
: 1 ; // Problem with the Non- Volatile memory 

// Hardware parity error 



unsigned MemFull 
unsigned MissPar 
unsigned MovErr 
unsigned NoMem 
unsigned NVRamErr 
unsigned ParityErr : 1 ; 



V 



54 



WO 98/15092 



PCT/US97/17407 



10 



unsigned PassErr : 1 ; // Double pass required, single pass module 

unsigned QueueFull : 1 ; // Print Queue full. No more jobs possible, 

unsigned ResErr : 1 ; // Image size did not match reserved memory 

unsigned SetUpErr : 1; // Request does not match system configuration 

unsigned SizeErr : 1 ; // Size in Img Header does not match image size 

unsigned StoErr : 1 ; // Video or Digital signal error during acquisition 

unsigned TimeOut : I; // Image acquistion could not be completed 

unsigned TooLbng ; 1 ; // Message is too long to fit in the mbox 

unsigned Unkillable : 1 ; // Job(s) cannont be killed 

unsigned UnknownCmd : 1; // Unknown command issued 

unsigned WinErr : 1 ; // Window specified is incorrect size 
} Failures; 



15 



20 



25 



30 



35 



40 



The following structure holds data that input imaging device 18 (the laser imager) 
returns if the command executes correctly. Thus, this data is only valid if no errors 
occurred during execution. 



typedef struct { 
ID id; 

LENGTH xsize; 
LENGTH y_size; 
LIST list; 
} Success_Data; 



// Place holder for a return ID 
// Place holder for an Image size 
// Place holder for an Image size 
// Place holder for an ID list 



The actual base class for output interpreter component 24 can be defined in C++ as 
follows: 

class LI_INTERFACE { 
public: 

LI JNTERFACE(PORTJD newjd, OUTPUT INTERFACE *p);//constructor 
~LIJNTERFACE(void); 



INT32 return cpde; 
DRIVER RC out_driver_rc; 
DEBUGJLEVELS debugjevel; 
Semaphore rpc_reply; 
Semaphore rpcjree; 
Semaphore event_reply; 
Semaphore event_free; 
PORTJD execjd; 
Mailbox rpcjnbox; 
Mailbox event_mbox; 



// RC for OS operations 
// RC from output driver 
// Debug level for module 
// RPC response complete 
//RPC mailbox free 
// async event received 
// async event mailbox free 



//RPC mailbox 
// event mailbox 
OUTPUT JNTERFACE *output_handle; 

FE_PTR client; // client module using us 

FE_METHODJPTR client_async_handler; // pointer to async handler 
virtual Bool output_ev_handler(enum IOJEVENT event) =0 

//asynch event handler 
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virtual void set_async Junc(FE_PTR,FE_METHOD_PTR>=0; 

//set ptr to FE handler 

/*** Laser Imager Client Interface ***/ 
// Basic Transparent Command 
5 virtual Lljresponse send(char *); //send generic text 

virtual LI response receive(char *); //receive generic text 
// Print Commands 

virtual LI response print(int copies=l)=0; //Fixed format print 
virtual Lljresponse print(FORMAT_ID id,LIST *images, 
10 int copies=l,DESTINATION d=Film^Prpcessor_l )=0; 

virtual Lljresponse print jest(FORMAT_lD id,LIST *images, 
IMAGE ID densjd,int copies=l, 
DESTINATION d=Fiim_ProcessorJ)=0; 
virtual LI response abort(JOB _ID id)=0; 
1 5 virtual LLresponse abort(void)=0; //Abort all jobs 

// Formatting Commands 

virtual Lljresponse define(BOX box)~0; //Define a box 

virtual LI response define(FORMAT format)=0; //Define a format 

virtual Lljresponse modify(BOX box)=0; //Modify a box 

20 virtual Lljresponse modify(LENGTH XSHIFT, LENGTH YjSHIFT, BOX 

box)=0; 

virtual L^response modify(FORMAT format)=0; //Modify a format 
virtual L^response remove(FIXED_ID); //Remove image from a position 
25 virtual Lljresponse remove(BOX box^Bool def=FALSE,Bool all=FALSE); 

//Del box 

virtual L^response remove(FORMAT format,Bool def=FALSE,Bool 
all=FALSE); 

30 virtual LI jresponse remove(IMAGE image,Bool def=FALSE,BooI all=FALSE); 
virtual LI response remove _fixed Jmages(void); //Remove all fixed images 
virtual LI response remove jall(Bool de£=FALSE); //Delete everything 
// Manipulation Commands 

virtual L^response reserve(IMAGE image)=0; //Reserve memory 
35 virtual LI response store(void)=0; //Store next image 

virtual LI jresponse store(FIXED _ID>=0; //Store image for a position 

virtual L^response store(IMAGE image)=0; //Store an image 
virtual Lljresponse store(TEST JMAGE image)=0; //Store a test image 
virtual L^response store(STRING string)=0; //Store a test image 
40 virtual Lljesponse transfer(IMAGE image)=0; //Transfer an image 
// Mailbox Commands 

virtual LI_response clear(MAILBOX mbox)=0; //Clear a mailbox 
virtual Lljresponse receive(MAILBOX mbox,char *msg>=0; 

//Get a msg into a mbox 
45 virtual LI response send(MAILBOX mbox,char *msg)=0; 

//Send a message to a mbox 

// Process configuration / status commands 
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virtual LIresponse set(PARAMETERS ptr)=0; //set imaging parameters 
virtual LI_response show_fixed(PARAMETERS *); 

virtual LI_response show_mem(PARAMETERS *ptr); //show image memory 
virtual Lljesponse show(PARAMETERS *ptr)=0; //show imag. params. 
5 virtual LI_response show(IMAGE *ptr)=0; //show info of image 

virtual LI_response show(Film_Processor *ptr)=0; //show status of a FP 
virtual Ll_response show(Image_Mgmnt_System *ptr)=0; //show IMS status 
virtual LI_response show(Printer *ptr)=0; //show status of Printer 

virtual LI_response show(Job *ptr)=0; //show status of a Job 

1 0 virtual LI_response show(Xfr *ptr)=0; //show status of Xfr job 

virtual LI response show formats(char *ptr)=0; //string of defined frmts 
virtual LI_response show_images(char *ptr)=0; //string of defined images 
virtual LIresponse show_con_tables(char *ptr)=0; //string of cont tables 
virtual LI_response show_ccon_tables(char *ptr)=0; //string of color con tbls 

15 }; 

The Output Driver Base-Class Protocol 

The output driver component 24 provides five remote procedure calls for 
output interpreter component 22. With the five remote procedure calls, output 
20 interpreter component 22 can directly interface with an output imaging device 18, 
such as a laser imager. Each of the five remote procedure calls is described below: 

1. xmitjnessage Parameters: Type: 

message char * 

25 Returns: Type: 

Driver return code DRIVER RC 

The above RPC passes output driver component 24 a message to transmit to input 
imaging device 12 via pipeline 30. The output driver component 26 handles all 
30 requirements for communication with output imaging device 1 8. 

2. receivejnessage Parameters: Type: 

message char * 

Returns: Type: 
Driver return code DRIVER RC 
35 The above RPC retrieves a message from output driver component 26 that has been 

sent from output imaging device 18. Again, output driver component 26 handles all 

requirements for communication with output imaging device! 

3. set__xmit_timeout Parameters: Type: 
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timeout int 
Returns: Type: 
Driver return code DRIVER_RC 
The above RPC sets the timeout value that output driver component 26 should use 
5 when sending to the output imaging device 18. 

4. set_asyncjunc Parameters: Type: 

client ptr FE_CLENT_PTR 
method ptr FE_METHOD_PTR 

Returns: Type: 

1 0 Driver return code DRIVER_RC 

The above RPC gives output driver component 26 a handle to the asynchronous 

handler of the client component, output interpreter component 24. The above RPC is 

used to inform the client component of asynchronous events that have occurred: The 

only event is MSGJPENDING which indicates a message has been fully received 

15 from output imaging device 18 and is ready for the output interpreter component 24. 

5. set debug level Parameters: Type: 

debug level DEBUG JJEVEL 

Returns: Type: 

* 

Driver return code DRIVER_RC 

20 The above RPC allows the client component to set the debug level for output driver 

component. The debug levels are NO_DEBUG, LOW J5EBUG, 

MEDIUM_DEBUG, and fflGH_DEBUG This parameter affects the information 

displayed during debugging. 

As noted above, each RPC returns one of three driver return codes: ( 1) 

25 RPC _OK, (2) PORTJSUSY, and (3) NO_MESSAGE. The driver return codes can 

be defined in C++ code as follows: 

//Set return types for I/O Driver interface 
typedef enum { 

RPC_OK, //RPC was issued and acknowledged 
30 PORTJ3USY, //Transmit RPC failed, port already transmitting 

NO MESSAGE //Receive RPC failed, no message pending 
}DRIVER_RC; 
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The actual base class protocol for output driver component 26 can be defined in C++ 

code as follows: 

class OUTPUTINTERFACE 
{ 

5 public: 

OUTPUT INTERFACE(PORT_ID newport); 
~OUTPUT_INTERFACE(void); 
virtual DRIVERRC xmit_message(char *message) = 0; 
virtual DRIVER RC receive_message(char *message) =0; 
1 0 virtual DRIVER RC set_xmit_timeout(int timeout) =0; 
virtual DRIVER RC set_async_fiinc(CLffiNT_PTR, 

CLIENTMETHODPTR) =0; // 
PORTJD port; //This port ID 



As the embodiments of the invention have already been described, additional 
advantages and modifications will readily occur to those skilled in the art from 
consideration of the specification and practice of the invention as is disclosed herein. 
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What is claimed is : 

1 . A software system for communicating medical image information 
between at least one of a plurality of different medical imaging modalities (12) and at 
least one of a plurality of different laser imagers (18) via a network interface (28), the 

5 software system comprising: 

one or more network interface components (33), each of the network 
interface components being configured to receive medical image information from 
one of the medical imaging modalities via the network interface, the medical image 
information being received according to one of a plurality of different network 

10 interface protocols, wherein each of the network interface protocols is specifically 
associated with one of the medical imaging modalities, and to generate first imaging 
requests based on the received medical image information, the first imaging requests 
being generated according to the one of the network interface protocols; 

one or more output interface components (16), each of the output interface 

1 5 components being configured to generate second imaging requests based on the first 
imaging requests generated by one of the network interface components, the second 
imaging requests being generated according to one of a plurality of different output 
interface protocols, wherein each of the output interface protocols is specifically 
associated with one of the laser imagers, and to communicate the second imaging 

20 requests generated by one of the output interface components to one of the laser 
imagers, the second imaging requests being communicated according to the one of 
the output interface protocols; and 

an interface executive component (20) for defining one or more 
communication pipelines (26), each of the pipelines communicatively interconnecting 

25 one of the medical imaging modalities, one of the network interface components, one 
of the output interface components, and one of the laser imagers. 

2. The software system of claim 1, wherein each of said network 
interface components includes a first interface for communicating the first imaging 
requests to one of said output interface components according to a base-class 

30 protocol generic to each of said network interface components and understood by 
each of said output interface components. 
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3: The software system of claim 2, wherein the base-class protocol is 
defined according to an object-oriented hierarchy. 

4. The software system of claim 2, wherein: 

each of said output interface components is further configured to receive first 
5 responses to the second imaging requests from one of said laser imagers, said first 
responses being received according to one of said output interface protocols, and to 
generate second responses based on said first responses, said second responses being 
generated according to one of said output interface protocols; and 

each of said network interface components is further configured to generate 

10 third responses based on said second responses generated by one of said output 

interface components, said third responses being generated according to one of said 
network interface protocols, and to communicate said third responses to one of said 
input imaging devices, said third responses being communicated according to one of 
said network interface protocols; and 

15 each of said pipelines defined by said interface executive component is a bi- 

directional pipeline communicatively interconnecting one of said input imaging 
devices, one of said network interface components, one of said output interface 
components, and one of said laser imagers for bi-directional communication between 
one of said medical imaging modalities and one of said laser imagers. 

20 5. The software system of claim 4, wherein each of said output interface 

components includes a second interface for communicating the second responses to 
one of said network interface components according to a second base-class protocol 
generic to each of said output interface components and understood by each of said 
network interface components. 

25 6. The software system of claim 4, wherein said interface executive 

component defines each of said pipelines according to a client-server relationship 
such that each of said network interface components is a client of one of said output 
interface components, and said interface executive component is a client of each of 
said network interface components. 

30 7. The software system of claim 6, wherein communication between said 

network interface components and said output interface components is carried out by 
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remote procedure calls generated by said network interface components and executed 
by said output interface components, and wherein communication between said 
interface executive component, said network interface components, and said output 
interface components is carried out by remote procedure calls generated by said 
5 interface executive component and executed by said network interface components. 

8. A device for imaging medical information communicated by one or 
more clients (12) on a network, comprising: 

network executive means (14) for, in response to receiving an imaging 
request from a client, generating a corresponding first imaging request; 
10 output interface means (16) for, in response to receiving the corresponding 

first imaging request from the network executive means, generating a corresponding 
second imaging request for transmission to the imaging device (18); and, 

interface executive means (20) for instantiating the network executive 
component according to an input protocol spoken by the client and the output 
15 interface component according to an output protocol spoken by the imaging device. 

9. The device of claim 8, wherein the network executive means 
instantiates: 

network driver means (30) according to a network driver protocol of the 
input protocol, for receiving from the client the imaging request; and, 
20 network interpreter means (32) according to a network interpreter protocol 

of the input protocol, for generating the corresponding first imaging request. 

10. The device of claim 7, wherein the output interface means comprises: 
output interpreter means (22) specific to an output interpreter protocol of the 

output interpreter protocol, for receiving the first imaging request from the network 
25 executive component and generating the corresponding second imaging request; and, 
output driver means (24) specific to an output driver protocol of the output 
protocol, for transmitting the corresponding second imaging request to the imaging 
device. 
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